



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | AVR                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 10MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 23                                                                        |
| Program Memory Size        | 8KB (4K x 16)                                                             |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 512 x 8                                                                   |
| RAM Size                   | 1K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.5V                                                               |
| Data Converters            | A/D 8x10b                                                                 |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 32-TQFP                                                                   |
| Supplier Device Package    | 32-TQFP (7x7)                                                             |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/atmega88v-10aur |

Email: info@E-XFL.COM

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

PWM mode is shown in Figure 12-6. The TCNT0 value is in the timing diagram shown as a histogram for illustrating the single-slope operation. The diagram includes non-inverted and inverted PWM outputs. The small horizontal line marks on the TCNT0 slopes represent compare matches between OCR0x and TCNT0.





The Timer/Counter Overflow Flag (TOV0) is set each time the counter reaches TOP. 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 OC0x pins. Setting the COM0x1:0 bits to two will produce a non-inverted PWM and an inverted PWM output can be generated by setting the COM0x1:0 to three: Setting the COM0A1:0 bits to one allows the OC0A pin to toggle on Compare Matches if the WGM02 bit is set. This option is not available for the OC0B pin (see Table 12-6 on page 100). The actual OC0x 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 OC0x Register at the compare match between OCR0x and TCNT0, and clearing (or setting) the OC0x Register at the timer clock cycle the counter is cleared (changes from TOP to BOTTOM).

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

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

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

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

A frequency (with 50% duty cycle) waveform output in fast PWM mode can be achieved by setting OC0x to toggle its logical level on each compare match (COM0x1:0 = 1). The waveform generated will have a maximum frequency of  $f_{OC0} = f_{clk}$   $_{1/O}/2$  when OCR0A is set to zero. This





prevents the occurrence of odd-length, non-symmetrical PWM pulses, thereby making the output glitch-free.

The OCR1x Register access may seem complex, but this is not case. When the double buffering is enabled, the CPU has access to the OCR1x Buffer Register, and if double buffering is disabled the CPU will access the OCR1x directly. The content of the OCR1x (Buffer or Compare) Register is only changed by a write operation (the Timer/Counter does not update this register automatically as the TCNT1 and ICR1 Register). Therefore OCR1x is not read via the high byte temporary register (TEMP). However, it is a good practice to read the low byte first as when accessing other 16-bit registers. Writing the OCR1x Registers must be done via the TEMP Register since the compare of all 16 bits is done continuously. The high byte (OCR1xH) has to be written first. When the high byte I/O location is written by the CPU, the TEMP Register will be updated by the value written. Then when the low byte (OCR1xL) is written to the lower eight bits, the high byte will be copied into the upper 8-bits of either the OCR1x buffer or OCR1x Compare Register in the same system clock cycle.

For more information of how to access the 16-bit registers refer to "Accessing 16-bit Registers" on page 108.

### 13.6.1 Force Output Compare

In non-PWM Waveform Generation modes, the match output of the comparator can be forced by writing a one to the *Force Output Compare* (FOC1x) bit. Forcing compare match will not set the OCF1x Flag or reload/clear the timer, but the OC1x pin will be updated as if a real compare match had occurred (the COM11:0 bits settings define whether the OC1x pin is set, cleared or toggled).

#### 13.6.2 Compare Match Blocking by TCNT1 Write

All CPU writes to the TCNT1 Register will block any compare match that occurs in the next timer clock cycle, even when the timer is stopped. This feature allows OCR1x to be initialized to the same value as TCNT1 without triggering an interrupt when the Timer/Counter clock is enabled.

# 13.6.3 Using the Output Compare Unit

Since writing TCNT1 in any mode of operation will block all compare matches for one timer clock cycle, there are risks involved when changing TCNT1 when using any of the Output Compare channels, independent of whether the Timer/Counter is running or not. If the value written to TCNT1 equals the OCR1x value, the compare match will be missed, resulting in incorrect waveform generation. Do not write the TCNT1 equal to TOP in PWM modes with variable TOP values. The compare match for the TOP will be ignored and the counter will continue to 0xFFFF. Similarly, do not write the TCNT1 value equal to BOTTOM when the counter is downcounting.

The setup of the OC1x should be performed before setting the Data Direction Register for the port pin to output. The easiest way of setting the OC1x value is to use the Force Output Compare (FOC1x) strobe bits in Normal mode. The OC1x Register keeps its value even when changing between Waveform Generation modes.

Be aware that the COM1x1:0 bits are not double buffered together with the compare value. Changing the COM1x1:0 bits will take effect immediately.



| Mode | WGM13 | WGM12<br>(CTC1) | WGM11<br>(PWM11) | WGM10<br>(PWM10) | Timer/Counter Mode of<br>Operation  | ТОР    | Update of<br>OCR1x at | TOV1 Flag<br>Set on |
|------|-------|-----------------|------------------|------------------|-------------------------------------|--------|-----------------------|---------------------|
| 0    | 0     | 0               | 0                | 0                | Normal                              | 0xFFFF | Immediate             | MAX                 |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Correct, 8-bit           | 0x00FF | ТОР                   | BOTTOM              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Correct, 9-bit           | 0x01FF | ТОР                   | BOTTOM              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Correct, 10-bit          | 0x03FF | ТОР                   | BOTTOM              |
| 4    | 0     | 1               | 0                | 0                | CTC                                 | OCR1A  | Immediate             | MAX                 |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit                     | 0x00FF | ТОР                   | ТОР                 |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit                     | 0x01FF | ТОР                   | ТОР                 |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit                    | 0x03FF | ТОР                   | ТОР                 |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and Frequency<br>Correct | ICR1   | BOTTOM                | BOTTOM              |
| 9    | 1     | 0               | 0                | 1                | PWM, Phase and Frequency<br>Correct | OCR1A  | BOTTOM                | BOTTOM              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Correct                  | ICR1   | ТОР                   | BOTTOM              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Correct                  | OCR1A  | ТОР                   | BOTTOM              |
| 12   | 1     | 1               | 0                | 0                | СТС                                 | ICR1   | Immediate             | MAX                 |
| 13   | 1     | 1               | 0                | 1                | (Reserved)                          | _      | _                     | _                   |
| 14   | 1     | 1               | 1                | 0                | Fast PWM                            | ICR1   | ТОР                   | ТОР                 |
| 15   | 1     | 1               | 1                | 1                | Fast PWM                            | OCR1A  | TOP                   | TOP                 |

 Table 13-4.
 Waveform Generation Mode Bit Description<sup>(1)</sup>

Note: 1. The CTC1 and PWM11:0 bit definition names are obsolete. Use the WGM12:0 definitions. However, the functionality and location of these bits are compatible with previous versions of the timer.

# 13.10.2 Timer/Counter1 Control Register B – TCCR1B

| Bit           | 7     | 6     | 5 | 4     | 3     | 2    | 1    | 0    |        |
|---------------|-------|-------|---|-------|-------|------|------|------|--------|
|               | ICNC1 | ICES1 | - | WGM13 | WGM12 | CS12 | CS11 | CS10 | TCCR1B |
| Read/Write    | R/W   | R/W   | R | R/W   | R/W   | R/W  | R/W  | R/W  |        |
| Initial Value | 0     | 0     | 0 | 0     | 0     | 0    | 0    | 0    |        |

# • Bit 7 – ICNC1: Input Capture Noise Canceler

Setting this bit (to one) activates the Input Capture Noise Canceler. When the noise canceler is activated, the input from the Input Capture pin (ICP1) is filtered. The filter function requires four successive equal valued samples of the ICP1 pin for changing its output. The Input Capture is therefore delayed by four Oscillator cycles when the noise canceler is enabled.

### Bit 6 – ICES1: Input Capture Edge Select

This bit selects which edge on the Input Capture pin (ICP1) that is used to trigger a capture event. When the ICES1 bit is written to zero, a falling (negative) edge is used as trigger, and when the ICES1 bit is written to one, a rising (positive) edge will trigger the capture.

When a capture is triggered according to the ICES1 setting, the counter value is copied into the Input Capture Register (ICR1). The event will also set the Input Capture Flag (ICF1), and this can be used to cause an Input Capture Interrupt, if this interrupt is enabled.



# 15.10 Timer/Counter Prescaler



Figure 15-12. Prescaler for Timer/Counter2

The clock source for Timer/Counter2 is named  $clk_{T2S}$ .  $clk_{T2S}$  is by default connected to the main system I/O clock  $clk_{IO}$ . By setting the AS2 bit in ASSR, Timer/Counter2 is asynchronously clocked from the TOSC1 pin. This enables use of Timer/Counter2 as a Real Time Counter (RTC). When AS2 is set, pins TOSC1 and TOSC2 are disconnected from Port C. A crystal can then be connected between the TOSC1 and TOSC2 pins to serve as an independent clock source for Timer/Counter2. The Oscillator is optimized for use with a 32.768 kHz crystal. Applying an external clock source to TOSC1 is not recommended.

For Timer/Counter2, the possible prescaled selections are:  $clk_{T2S}/8$ ,  $clk_{T2S}/32$ ,  $clk_{T2S}/64$ ,  $clk_{T2S}/128$ ,  $clk_{T2S}/256$ , and  $clk_{T2S}/1024$ . Additionally,  $clk_{T2S}$  as well as 0 (stop) may be selected. Setting the PSRASY bit in GTCCR resets the prescaler. This allows the user to operate with a predictable prescaler.

# 15.10.1 General Timer/Counter Control Register – GTCCR



# Bit 1 – PSRASY: Prescaler Reset Timer/Counter2

When this bit is one, the Timer/Counter2 prescaler will be reset. This bit is normally cleared immediately by hardware. If the bit is written when Timer/Counter2 is operating in asynchronous mode, the bit will remain one until the prescaler has been reset. The bit will not be cleared by hardware if the TSM bit is set. Refer to the description of the "Bit 7 – TSM: Timer/Counter Synchronization Mode" on page 137 for a description of the Timer/Counter Synchronization mode.

| Table 16-1. | SPI Pin Overrides <sup>(Note:)</sup> |
|-------------|--------------------------------------|
|-------------|--------------------------------------|

| Pin  | Direction, Master SPI | Direction, Slave SPI |
|------|-----------------------|----------------------|
| MOSI | User Defined          | Input                |
| MISO | Input                 | User Defined         |
| SCK  | User Defined          | Input                |
| SS   | User Defined          | Input                |

Note: See "Alternate Functions of Port B" on page 71 for a detailed description of how to define the direction of the user defined SPI pins.

The following code examples show how to initialize the SPI as a Master and how to perform a simple transmission. DDR\_SPI in the examples must be replaced by the actual Data Direction Register controlling the SPI pins. DD\_MOSI, DD\_MISO and DD\_SCK must be replaced by the actual data direction bits for these pins. E.g. if MOSI is placed on pin PB5, replace DD\_MOSI with DDB5 and DDR\_SPI with DDRB.





Assembly Code Example<sup>(1)</sup>

```
SPI_MasterInit:
     ; Set MOSI and SCK output, all others input
     ldi r17, (1<<DD_MOSI) | (1<<DD_SCK)
     out DDR_SPI,r17
     ; Enable SPI, Master, set clock rate fck/16
     ldi r17,(1<<SPE) | (1<<MSTR) | (1<<SPR0)
     out SPCR, r17
     ret
   SPI_MasterTransmit:
     ; Start transmission of data (r16)
     out SPDR, r16
   Wait_Transmit:
     ; Wait for transmission complete
     sbis SPSR, SPIF
     rjmp Wait_Transmit
     ret
C Code Example<sup>(1)</sup>
   void SPI_MasterInit(void)
   {
     /* Set MOSI and SCK output, all others input */
     DDR_SPI = (1<<DD_MOSI) | (1<<DD_SCK);
     /* Enable SPI, Master, set clock rate fck/16 */
     SPCR = (1<<SPE) | (1<<MSTR) | (1<<SPR0);
   }
   void SPI_MasterTransmit(char cData)
   {
     /* Start transmission */
     SPDR = cData;
     /* Wait for transmission complete */
     while(!(SPSR & (1<<SPIF)))</pre>
       ;
   }
```

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



# 16.1.4 SPI Status Register – SPSR

| Bit           | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0     |      |
|---------------|------|------|---|---|---|---|---|-------|------|
|               | SPIF | WCOL | - | - | - | - | - | SPI2X | SPSR |
| Read/Write    | R    | R    | R | R | R | R | R | R/W   |      |
| Initial Value | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0     |      |

# • Bit 7 – SPIF: SPI Interrupt Flag

When a serial transfer is complete, the SPIF Flag is set. An interrupt is generated if SPIE in SPCR is set and global interrupts are enabled. If  $\overline{SS}$  is an input and is driven low when the SPI is in Master mode, this will also set the SPIF Flag. SPIF is cleared by hardware when executing the corresponding interrupt handling vector. Alternatively, the SPIF bit is cleared by first reading the SPI Status Register with SPIF set, then accessing the SPI Data Register (SPDR).

#### Bit 6 – WCOL: Write COLlision Flag

The WCOL bit is set if the SPI Data Register (SPDR) is written during a data transfer. The WCOL bit (and the SPIF bit) are cleared by first reading the SPI Status Register with WCOL set, and then accessing the SPI Data Register.

#### • Bit 5..1 - Res: Reserved Bits

These bits are reserved bits in the ATmega48/88/168 and will always read as zero.

#### Bit 0 – SPI2X: Double SPI Speed Bit

When this bit is written logic one the SPI speed (SCK Frequency) will be doubled when the SPI is in Master mode (see Table 16-4). This means that the minimum SCK period will be two CPU clock periods. When the SPI is configured as Slave, the SPI is only guaranteed to work at  $f_{osc}/4$  or lower.

The SPI interface on the ATmega48/88/168 is also used for program memory and EEPROM downloading or uploading. See page 295 for serial programming and verification.

### 16.1.5 SPI Data Register – SPDR



The SPI Data Register is a read/write register used for data transfer between the Register File and the SPI Shift Register. Writing to the register initiates data transmission. Reading the register causes the Shift Register Receive buffer to be read.

# 16.2 Data Modes

There are four combinations of SCK phase and polarity with respect to serial data, which are determined by control bits CPHA and CPOL. The SPI data transfer formats are shown in Figure 16-3 and Figure 16-4. Data bits are shifted out and latched in on opposite edges of the SCK signal, ensuring sufficient time for data signals to stabilize. This is clearly seen by summarizing Table 16-2 and Table 16-3, as done below.



# 18.4 Frame Formats

A serial frame for the MSPIM is defined to be one character of 8 data bits. The USART in MSPIM mode has two valid frame formats:

- 8-bit data with MSB first
- 8-bit data with LSB first

A frame starts with the least or most significant data bit. Then the next data bits, up to a total of eight, are succeeding, ending with the most or least significant bit accordingly. When a complete frame is transmitted, a new frame can directly follow it, or the communication line can be set to an idle (high) state.

The UDORDn bit in UCSRnC sets the frame format used by the USART in MSPIM mode. The Receiver and Transmitter use the same setting. Note that changing the setting of any of these bits will corrupt all ongoing communication for both the Receiver and Transmitter.

16-bit data transfer can be achieved by writing two data bytes to UDRn. A UART transmit complete interrupt will then signal that the 16-bit value has been shifted out.

# 18.4.1 USART MSPIM Initialization

The USART in MSPIM mode has to be initialized before any communication can take place. The initialization process normally consists of setting the baud rate, setting master mode of operation (by setting DDR\_XCKn to one), setting frame format and enabling the Transmitter and the Receiver. Only the transmitter can operate independently. For interrupt driven USART operation, the Global Interrupt Flag should be cleared (and thus interrupts globally disabled) when doing the initialization.

Note: To ensure immediate initialization of the XCKn output the baud-rate register (UBRRn) must be zero at the time the transmitter is enabled. Contrary to the normal mode USART operation the UBRRn must then be written to the desired value after the transmitter is enabled, but before the first transmission is started. Setting UBRRn to zero before enabling the transmitter is not necessary if the initialization is done immediately after a reset since UBRRn is reset to zero.

Before doing a re-initialization with changed baud rate, data mode, or frame format, be sure that there is no ongoing transmissions during the period the registers are changed. The TXCn Flag can be used to check that the Transmitter has completed all transfers, and the RXCn Flag can be used to check that there are no unread data in the receive buffer. Note that the TXCn Flag must be cleared before each transmission (before UDRn is written) if it is used for this purpose.

The following simple USART initialization code examples show one assembly and one C function that are equal in functionality. The examples assume polling (no interrupts enabled). The baud rate is given as a function parameter. For the assembly code, the baud rate parameter is assumed to be stored in the r17:r16 registers.

| Assembly Code Example <sup>(1)</sup>                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------|
| USART_Init:                                                                                                                 |
| clr r18                                                                                                                     |
| out UBRRnH,r18                                                                                                              |
| out UBRRnL,r18                                                                                                              |
| ; Setting the XCKn port pin as output, enables master mode.                                                                 |
| <b>sbi</b> XCKn_DDR, XCKn                                                                                                   |
| ; Set MSPI mode of operation and SPI data mode 0.                                                                           |
| <b>ldi</b> r18, (1< <umseln1) (1<<umseln0) (0<<ucphan) (0<<ucpoln)< th=""></umseln1) (1<<umseln0) (0<<ucphan) (0<<ucpoln)<> |
| out UCSRnC,r18                                                                                                              |
| ; Enable receiver and transmitter.                                                                                          |
| <b>ldi</b> r18, (1< <rxenn) (1<<txenn)<="" th=""  =""></rxenn)>                                                             |
| out UCSRnB,r18                                                                                                              |
| ; Set baud rate.                                                                                                            |
| ; IMPORTANT: The Baud Rate must be set after the transmitter is enabled!                                                    |
| out UBRRnH, r17                                                                                                             |
| out UBRRnL, r18                                                                                                             |
| ret                                                                                                                         |
| C Code Example <sup>(1)</sup>                                                                                               |
| <b>void</b> USART_Init( <b>unsigned int</b> baud )                                                                          |
| {                                                                                                                           |
| UBRRn = 0;                                                                                                                  |
| /* Setting the XCKn port pin as output, enables master mode. */                                                             |
| XCKn_DDR = (1< <xckn);< th=""></xckn);<>                                                                                    |
| /* Set MSPI mode of operation and SPI data mode 0. */                                                                       |
| UCSRnC = (1< <umseln1) (0<<ucphan)="" (0<<ucpoln);<="" (1<<umseln0)="" th=""  =""></umseln1)>                               |
| /* Enable receiver and transmitter. */                                                                                      |
| UCSRnB = (1 << RXENn)   (1 << TXENn);                                                                                       |
| /* Set baud rate. */                                                                                                        |
| /* IMPORTANT: The Baud Rate must be set after the transmitter is enabled $^{*/}$                                            |
| UBRRn = baud;                                                                                                               |
| }                                                                                                                           |



# 18.5 Data Transfer

Using the USART in MSPI mode requires the Transmitter to be enabled, i.e. the TXENn bit in the UCSRnB register is set to one. When the Transmitter is enabled, the normal port operation of the TxDn pin is overridden and given the function as the Transmitter's serial output. Enabling the receiver is optional and is done by setting the RXENn bit in the UCSRnB register to one. When the receiver is enabled, the normal pin operation of the RxDn pin is overridden and given the function as the Receiver's serial input. The XCKn will in both cases be used as the transfer clock.





|               | RXCn | TXCn | UDREn | - | - | - | - | - | UCSRnA |
|---------------|------|------|-------|---|---|---|---|---|--------|
| Read/Write    | R/W  | R/W  | R/W   | R | R | R | R | R | •      |
| Initial Value | 0    | 0    | 0     | 0 | 0 | 1 | 1 | 0 |        |

# • Bit 7 - RXCn: USART Receive Complete

This flag bit is set when there are unread data in the receive buffer and cleared when the receive buffer is empty (i.e., does not contain any unread data). If the Receiver is disabled, the receive buffer will be flushed and consequently the RXCn bit will become zero. The RXCn Flag can be used to generate a Receive Complete interrupt (see description of the RXCIEn bit).

# • Bit 6 - TXCn: USART Transmit Complete

This flag bit is set when the entire frame in the Transmit Shift Register has been shifted out and there are no new data currently present in the transmit buffer (UDRn). The TXCn Flag bit is automatically cleared when a transmit complete interrupt is executed, or it can be cleared by writing a one to its bit location. The TXCn Flag can generate a Transmit Complete interrupt (see description of the TXCIEn bit).

#### • Bit 5 - UDREn: USART Data Register Empty

The UDREn Flag indicates if the transmit buffer (UDRn) is ready to receive new data. If UDREn is one, the buffer is empty, and therefore ready to be written. The UDREn Flag can generate a Data Register Empty interrupt (see description of the UDRIE bit). UDREn is set after a reset to indicate that the Transmitter is ready.

# • Bit 4:0 - Reserved Bits in MSPI mode

When in MSPI mode, these bits are reserved for future use. For compatibility with future devices, these bits must be written to zero when UCSRnA is written.

# 18.6.3 USART MSPIM Control and Status Register n B - UCSRnB



# Bit 7 - RXCIEn: RX Complete Interrupt Enable

Writing this bit to one enables interrupt on the RXCn Flag. A USART Receive Complete interrupt will be generated only if the RXCIEn bit is written to one, the Global Interrupt Flag in SREG is written to one and the RXCn bit in UCSRnA is set.

#### • Bit 6 - TXCIEn: TX Complete Interrupt Enable

Writing this bit to one enables interrupt on the TXCn Flag. A USART Transmit Complete interrupt will be generated only if the TXCIEn bit is written to one, the Global Interrupt Flag in SREG is written to one and the TXCn bit in UCSRnA is set.

#### • Bit 5 - UDRIE: USART Data Register Empty Interrupt Enable

Writing this bit to one enables interrupt on the UDREn Flag. A Data Register Empty interrupt will be generated only if the UDRIE bit is written to one, the Global Interrupt Flag in SREG is written to one and the UDREn bit in UCSRnA is set.

• Bit 4 - RXENn: Receiver Enable



#### 19.3.4 Data Packet Format

All data packets transmitted on the TWI bus are nine bits long, consisting of one data byte and an acknowledge bit. During a data transfer, the Master generates the clock and the START and STOP conditions, while the Receiver is responsible for acknowledging the reception. An Acknowledge (ACK) is signalled by the Receiver pulling the SDA line low during the ninth SCL cycle. If the Receiver leaves the SDA line high, a NACK is signalled. When the Receiver has received the last byte, or for some reason cannot receive any more bytes, it should inform the Transmitter by sending a NACK after the final byte. The MSB of the data byte is transmitted first.

# Figure 19-5. Data Packet Format



# 19.3.5 Combining Address and Data Packets into a Transmission

A transmission basically consists of a START condition, a SLA+R/W, one or more data packets and a STOP condition. An empty message, consisting of a START followed by a STOP condition, is illegal. Note that the Wired-ANDing of the SCL line can be used to implement handshaking between the Master and the Slave. The Slave can extend the SCL low period by pulling the SCL line low. This is useful if the clock speed set up by the Master is too fast for the Slave, or the Slave needs extra time for processing between the data transmissions. The Slave extending the SCL low period will not affect the SCL high period, which is determined by the Master. As a consequence, the Slave can reduce the TWI data transfer speed by prolonging the SCL duty cycle.

Figure 19-6 shows a typical data transmission. Note that several data bytes can be transmitted between the SLA+R/W and the STOP condition, depending on the software protocol implemented by the application software.







Figure 21-10. Offset Error



 Gain error: After adjusting for offset, the gain error is found as the deviation of the last transition (0x3FE to 0x3FF) compared to the ideal transition (at 1.5 LSB below maximum). Ideal value: 0 LSB





• Integral Non-linearity (INL): After adjusting for offset and gain error, the INL is the maximum deviation of an actual transition compared to an ideal transition for any code. Ideal value: 0 LSB.



trigger signal. If ADEN in ADCSRA is set, this will start a conversion. Switching to Free Running mode (ADTS[2:0]=0) will not cause a trigger event, even if the ADC Interrupt Flag is set.

| ADTS2 | ADTS1 | ADTS0 | Trigger Source                 |
|-------|-------|-------|--------------------------------|
| 0     | 0     | 0     | Free Running mode              |
| 0     | 0     | 1     | Analog Comparator              |
| 0     | 1     | 0     | External Interrupt Request 0   |
| 0     | 1     | 1     | Timer/Counter0 Compare Match A |
| 1     | 0     | 0     | Timer/Counter0 Overflow        |
| 1     | 0     | 1     | Timer/Counter1 Compare Match B |
| 1     | 1     | 0     | Timer/Counter1 Overflow        |
| 1     | 1     | 1     | Timer/Counter1 Capture Event   |

 Table 21-5.
 ADC Auto Trigger Source Selections

# 21.6.5 Digital Input Disable Register 0 – DIDR0



# • Bits 7:6 - Res: Reserved Bits

These bits are reserved for future use. To ensure compatibility with future devices, these bits must be written to zero when DIDR0 is written.

#### • Bit 5:0 – ADC5D..ADC0D: ADC5..0 Digital Input Disable

When this bit is written logic one, the digital input buffer on the corresponding ADC 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 ADC5..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.

Note that ADC pins ADC7 and ADC6 do not have digital input buffers, and therefore do not require Digital Input Disable bits.



# 24.7.1 Performing Page Erase by SPM

To execute Page Erase, set up the address in the Z-pointer, write "X0000011" to SPMCSR and execute SPM within four clock cycles after writing SPMCSR. The data in R1 and R0 is ignored. The page address must be written to PCPAGE in the Z-register. Other bits in the Z-pointer will be ignored during this operation.

- Page Erase to the RWW section: The NRWW section can be read during the Page Erase.
- Page Erase to the NRWW section: The CPU is halted during the operation.

# 24.7.2 Filling the Temporary Buffer (Page Loading)

To write an instruction word, set up the address in the Z-pointer and data in R1:R0, write "00000001" to SPMCSR and execute SPM within four clock cycles after writing SPMCSR. The content of PCWORD in the Z-register is used to address the data in the temporary buffer. The temporary buffer will auto-erase after a Page Write operation or by writing the RWWSRE bit in SPMCSR. It is also erased after a system reset. Note that it is not possible to write more than one time to each address without erasing the temporary buffer.

If the EEPROM is written in the middle of an SPM Page Load operation, all data loaded will be lost.

# 24.7.3 Performing a Page Write

To execute Page Write, set up the address in the Z-pointer, write "X0000101" to SPMCSR and execute SPM within four clock cycles after writing SPMCSR. The data in R1 and R0 is ignored. The page address must be written to PCPAGE. Other bits in the Z-pointer must be written to zero during this operation.

- Page Write to the RWW section: The NRWW section can be read during the Page Write.
- Page Write to the NRWW section: The CPU is halted during the operation.

#### 24.7.4 Using the SPM Interrupt

If the SPM interrupt is enabled, the SPM interrupt will generate a constant interrupt when the SELFPRGEN bit in SPMCSR is cleared. This means that the interrupt can be used instead of polling the SPMCSR Register in software. When using the SPM interrupt, the Interrupt Vectors should be moved to the BLS section to avoid that an interrupt is accessing the RWW section when it is blocked for reading. How to move the interrupts is described in "Watchdog Timer" on page 49.

#### 24.7.5 Consideration While Updating BLS

Special care must be taken if the user allows the Boot Loader section to be updated by leaving Boot Lock bit11 unprogrammed. An accidental write to the Boot Loader itself can corrupt the entire Boot Loader, and further software updates might be impossible. If it is not necessary to change the Boot Loader software itself, it is recommended to program the Boot Lock bit11 to protect the Boot Loader software from any internal software changes.

# 24.7.6 Prevent Reading the RWW Section During Self-Programming

During Self-Programming (either Page Erase or Page Write), the RWW section is always blocked for reading. The user software itself must prevent that this section is addressed during the self programming operation. The RWWSB in the SPMCSR will be set as long as the RWW section is busy. During Self-Programming the Interrupt Vector table should be moved to the BLS as described in "Watchdog Timer" on page 49, or the interrupts must be disabled. Before addressing the RWW section after the programming is completed, the user software must clear

# 272 ATmega48/88/168



- 4. Give XTAL1 a positive pulse. This loads the address low byte.
- C. Load Data Low Byte
- 1. Set XA1, XA0 to "01". This enables data loading.
- 2. Set DATA = Data low byte (0x00 0xFF).
- 3. Give XTAL1 a positive pulse. This loads the data byte.
- D. Load Data High Byte
- 1. Set BS1 to "1". This selects high data byte.
- 2. Set XA1, XA0 to "01". This enables data loading.
- 3. Set DATA = Data high byte (0x00 0xFF).
- 4. Give XTAL1 a positive pulse. This loads the data byte.
- E. Latch Data
- 1. Set BS1 to "1". This selects high data byte.
- 2. Give PAGEL a positive pulse. This latches the data bytes. (See Figure 25-3 for signal waveforms)

F. Repeat B through E until the entire buffer is filled or until all data within the page is loaded.

While the lower bits in the address are mapped to words within the page, the higher bits address the pages within the FLASH. This is illustrated in Figure 25-2 on page 289. Note that if less than eight bits are required to address words in the page (pagesize < 256), the most significant bit(s) in the address low byte are used to address the page when performing a Page Write.

- G. Load Address High byte
- 1. Set XA1, XA0 to "00". This enables address loading.
- 2. Set BS1 to "1". This selects high address.
- 3. Set DATA = Address high byte (0x00 0xFF).
- 4. Give XTAL1 a positive pulse. This loads the address high byte.
- H. Program Page
- 1. Give WR a negative pulse. This starts programming of the entire page of data. RDY/BSY goes low.
- 2. Wait until RDY/BSY goes high (See Figure 25-3 for signal waveforms).

I. Repeat B through H until the entire Flash is programmed or until all data has been programmed.

J. End Page Programming

- 1. 1. Set XA1, XA0 to "10". This enables command loading.
- 2. Set DATA to "0000 0000". This is the command for No Operation.
- 3. Give XTAL1 a positive pulse. This loads the command, and the internal write signals are reset.



| $T_A = -40^{\circ}C$ to 85°C, $V_{CC} = 1.8V$ to | 5.5V (unless otherwise noted) | (Continued) |
|--------------------------------------------------|-------------------------------|-------------|
|--------------------------------------------------|-------------------------------|-------------|

| Symbol            | Parameter                                  | Condition                                               | Min. <sup>(5)</sup> | Тур.       | Max. <sup>(5)</sup> | Units |
|-------------------|--------------------------------------------|---------------------------------------------------------|---------------------|------------|---------------------|-------|
| R <sub>RST</sub>  | Reset Pull-up Resistor                     |                                                         | 30                  |            | 60                  | kΩ    |
| R <sub>PU</sub>   | I/O Pin Pull-up Resistor                   |                                                         | 20                  |            | 50                  | kΩ    |
|                   |                                            | Active 1MHz, V <sub>CC</sub> = 2V<br>(ATmega48/88/168V) |                     |            | 0.55                | mA    |
|                   |                                            | Active 4MHz, V <sub>CC</sub> = 3V<br>(ATmega48/88/168L) |                     |            | 3.5                 | mA    |
|                   | Dower Cupply Current(6)                    | Active 8MHz, V <sub>CC</sub> = 5V<br>(ATmega48/88/168)  |                     |            | 12                  | mA    |
| I <sub>CC</sub>   | Power Supply Current <sup>(6)</sup>        | Idle 1MHz, V <sub>CC</sub> = 2V<br>(ATmega48/88/168V)   |                     | 0.25       | 0.5                 | mA    |
|                   |                                            | Idle 4MHz, V <sub>CC</sub> = 3V<br>(ATmega48/88/168L)   |                     |            | 1.5                 | mA    |
|                   |                                            | Idle 8MHz, V <sub>CC</sub> = 5V<br>(ATmega48/88/168)    |                     |            | 5.5                 | mA    |
|                   | Deview devie meede                         | WDT enabled, $V_{CC} = 3V$                              |                     | <8         | 15                  | μA    |
|                   | Power-down mode                            | WDT disabled, $V_{CC} = 3V$                             |                     | <1         | 2                   | μA    |
| V <sub>ACIO</sub> | Analog Comparator<br>Input Offset Voltage  | $V_{CC} = 5V$<br>$V_{in} = V_{CC}/2$                    |                     | <10        | 40                  | mV    |
| I <sub>ACLK</sub> | Analog Comparator<br>Input Leakage Current | $V_{CC} = 5V$ $V_{in} = V_{CC}/2$                       | -50                 |            | 50                  | nA    |
| t <sub>ACID</sub> | Analog Comparator<br>Propagation Delay     | V <sub>CC</sub> = 2.7V<br>V <sub>CC</sub> = 4.0V        |                     | 750<br>500 |                     | ns    |

Notes: 1. "Max" means the highest value where the pin is guaranteed to be read as low

2. "Min" means the lowest value where the pin is guaranteed to be read as high

Although each I/O port can sink more than the test conditions (20mA at V<sub>CC</sub> = 5V, 10mA at V<sub>CC</sub> = 3V) under steady state conditions (non-transient), the following must be observed:

- ATmega48:
- 1] The sum of all IOL, for ports C0 C5, should not exceed 100 mA.
- 2] The sum of all IOL, for ports C6, D0 D4, should not exceed 100 mA.
- 3] The sum of all IOL, for ports B0 B7, D5 D7, should not exceed 100 mA.
- ATmega88/168:
- 1] The sum of all IOL, for ports C0 C5, should not exceed 100 mA.
- 2] The sum of all IOL, for ports C6, D0 D4, should not exceed 100 mA.
- 3] The sum of all IOL, for ports B0 B7, D5 D7, should not exceed 100 mA.

If IOL exceeds the test condition, VOL may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test condition.

- Although each I/O port can source more than the test conditions (20mA at V<sub>CC</sub> = 5V, 10mA at V<sub>CC</sub> = 3V) under steady state conditions (non-transient), the following must be observed:
  - ATmega48:
  - 1] The sum of all IOH, for ports C0 C5, should not exceed 100 mA.
  - 2] The sum of all IOH, for ports C6, D0 D4, should not exceed 100 mA.
  - 3] The sum of all IOH, for ports B0 B7, D5 D7, should not exceed 100 mA.
  - ATmega88/168:
  - 1] The sum of all IOH, for ports C0 C5, should not exceed 100 mA.
  - 2] The sum of all IOH, for ports C6, D0 D4, should not exceed 100 mA.
  - 3] The sum of all IOH, for ports B0 B7, D5 D7, should not exceed 100 mA.





Figure 26-6. SPI Interface Timing Requirements (Slave Mode)











Figure 27-36. Bandgap Voltage vs. V<sub>CC</sub>







|                | 6.10Timer/Counter Oscillator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|                | 6.11System Clock Prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |
| 7              | Power Management and Sleep Modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |
|                | 7.1Idle Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |
|                | 7.2ADC Noise Reduction Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                  |
|                | 7.3Power-down Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                  |
|                | 7.4Power-save Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                  |
|                | 7.5Standby Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |
|                | 7.6Power Reduction Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                  |
|                | 7.7Minimizing Power Consumption                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 41               |
| 8              | System Control and Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 43               |
|                | 8.1 Internal Voltage Reference                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 48               |
|                | 8.2Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 49               |
| 9              | Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 54               |
|                | 9.1Interrupt Vectors in ATmega48                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 54               |
|                | 9.2Interrupt Vectors in ATmega88                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |
|                | 9.3Interrupt Vectors in ATmega168                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 59               |
|                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |
| 10             | I/O-Ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                  |
| 10             | 10.1Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b> 64</b><br>64 |
| 10             | 10.1Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |
| 10             | 10.1Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |
| 10             | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |
| 10<br>11       | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         External Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                              |                  |
| 10<br>11       | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         External Interrupts         11.1Pin Change Interrupt Timing                                                                                                                                                                                                                                                                                                                                                                                      |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         External Interrupts         11.1Pin Change Interrupt Timing         8-bit Timer/Counter0 with PWM                                                                                                                                                                                                                                                                                                                                                |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports <b>External Interrupts</b> 11.1Pin Change Interrupt Timing <b>8-bit Timer/Counter0 with PWM</b> 12.1Overview                                                                                                                                                                                                                                                                                                                                             |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports <b>External Interrupts</b> 11.1Pin Change Interrupt Timing <b>8-bit Timer/Counter0 with PWM</b> 12.1Overview         12.2Timer/Counter Clock Sources                                                                                                                                                                                                                                                                                                     |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         External Interrupts         11.1Pin Change Interrupt Timing         8-bit Timer/Counter0 with PWM         12.1Overview         12.2Timer/Counter Clock Sources         12.3Counter Unit                                                                                                                                                                                                                                                          |                  |
| 10<br>11<br>12 | <ul> <li>I/O-PORTS</li> <li>10.1Introduction</li> <li>10.2Ports as General Digital I/O</li> <li>10.3Alternate Port Functions</li> <li>10.4Register Description for I/O Ports</li> <li>I0.4Register Description for I/O Ports</li> <li>I1.1Pin Change Interrupts</li> <li>I1.1Pin Change Interrupt Timing</li> <li>8-bit Timer/Counter0 with PWM</li> <li>12.1Overview</li> <li>12.2Timer/Counter Clock Sources</li> <li>12.3Counter Unit</li> <li>12.4Output Compare Unit</li> </ul>                                                                                                                                     |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         10.4Register Description for I/O Ports         11.1Pin Change Interrupts         11.1Pin Change Interrupt Timing         8-bit Timer/Counter0 with PWM         12.1Overview         12.2Timer/Counter Clock Sources         12.3Counter Unit         12.4Output Compare Unit         12.5Compare Match Output Unit                                                                                                                               |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         10.4Register Description for I/O Ports         11.1Pin Change Interrupts         11.1Pin Change Interrupt Timing         8-bit Timer/Counter0 with PWM         12.1Overview         12.2Timer/Counter Clock Sources         12.3Counter Unit         12.4Output Compare Unit         12.5Compare Match Output Unit         12.6Modes of Operation                                                                                                |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         10.4Register Description for I/O Ports         11.1Pin Change Interrupts         11.1Pin Change Interrupt Timing         8-bit Timer/Counter0 with PWM         12.1Overview         12.2Timer/Counter Clock Sources         12.3Counter Unit         12.4Output Compare Unit         12.5Compare Match Output Unit         12.6Modes of Operation         12.7Timer/Counter Timing Diagrams                                                      |                  |
| 10<br>11<br>12 | I/O-Ports         10.1Introduction         10.2Ports as General Digital I/O         10.3Alternate Port Functions         10.4Register Description for I/O Ports         10.4Register Description for I/O Ports         11.1Pin Change Interrupts         11.1Pin Change Interrupt Timing         8-bit Timer/Counter0 with PWM         12.1Overview         12.2Timer/Counter Clock Sources         12.3Counter Unit         12.4Output Compare Unit         12.5Compare Match Output Unit         12.6Modes of Operation         12.7Timer/Counter Timing Diagrams         12.88-bit Timer/Counter Register Description |                  |



|    | 27.4Power-Down Supply Current                           | 315 |
|----|---------------------------------------------------------|-----|
|    | 27.5Power-Save Supply Current                           |     |
|    | 27.6Standby Supply Current                              |     |
|    | 27.7Pin Pull-up                                         |     |
|    | 27.8Pin Driver Strength                                 |     |
|    | 27.9Pin Thresholds and Hysteresis                       |     |
|    | 27.10BOD Thresholds and Analog Comparator Offset        |     |
|    | 27.11Internal Oscillator Speed                          | 328 |
|    | 27.12Current Consumption of Peripheral Units            |     |
|    | 27.13Current Consumption in Reset and Reset Pulse width |     |
| 28 | Register Summary                                        |     |
| 29 | Instruction Set Summary                                 |     |
| 30 | Ordering Information                                    |     |
|    | 30.1ATmega48                                            |     |
|    | 30.2ATmega88                                            |     |
|    | 30.3ATmega168                                           |     |
| 31 | Packaging Information                                   |     |
|    | 31.132A                                                 |     |
|    | 31.228P3                                                | 345 |
|    | 31.332M1-A                                              |     |
| 32 | Errata                                                  |     |
|    | 32.1Errata ATmega48                                     |     |
|    | 32.2Errata ATmega88                                     |     |
|    | 32.3Errata ATmega168                                    |     |
| 33 | Datasheet Revision History                              |     |
|    | 33.1Rev. 2545E-02/05                                    | 350 |
|    | 33.2Rev. 2545D-07/04                                    | 350 |
|    | 33.3Rev. 2545C-04/04                                    | 350 |
|    | 33.4Rev. 2545B-01/04                                    | 351 |
|    | Table of Contents                                       | i   |