

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

E·XFI

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | AVR                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 20MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 32                                                                        |
| Program Memory Size        | 32KB (16K x 16)                                                           |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 1K x 8                                                                    |
| RAM Size                   | 2K 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             | 44-TQFP                                                                   |
| Supplier Device Package    | 44-TQFP (10x10)                                                           |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/atmega324p-20au |

Email: info@E-XFL.COM

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

# 5.4 EEPROM Data Memory

The ATmega164P/324P/644P contains 512B/1K/2K bytes of data EEPROM memory. It is organized as a separate data space, in which single bytes can be read and written. The EEPROM has an endurance of at least 100,000 write/erase cycles. The access between the EEPROM and the CPU is described in the following, specifying the EEPROM Address Registers, the EEPROM Data Register, and the EEPROM Control Register.

For a detailed description of SPI, JTAG and Parallel data downloading to the EEPROM, see page 308, page 312, and page 297 respectively.

## 5.4.1 EEPROM Read/Write Access

The EEPROM Access Registers are accessible in the I/O space. See "Register Description" on page 23 for details.

The write access time for the EEPROM is given in Table 5-2 on page 25. A self-timing function, however, lets the user software detect when the next byte can be written. If the user code contains instructions that write the EEPROM, some precautions must be taken. In heavily filtered power supplies,  $V_{CC}$  is likely to rise or fall slowly on power-up/down. This causes the device for some period of time to run at a voltage lower than specified as minimum for the clock frequency used. See Section "5.4.2" on page 21. for details on how to avoid problems in these situations.

In order to prevent unintentional EEPROM writes, a specific write procedure must be followed. Refer to the description of the EEPROM Control Register for details on this.

When the EEPROM is read, the CPU is halted for four clock cycles before the next instruction is executed. When the EEPROM is written, the CPU is halted for two clock cycles before the next instruction is executed.

## 5.4.2 Preventing EEPROM Corruption

During periods of low  $V_{CC}$ , the EEPROM data can be corrupted because the supply voltage is too low for the CPU and the EEPROM to operate properly. These issues are the same as for board level systems using EEPROM, and the same design solutions should be applied.

An EEPROM data corruption can be caused by two situations when the voltage is too low. First, a regular write sequence to the EEPROM requires a minimum voltage to operate correctly. Secondly, the CPU itself can execute instructions incorrectly, if the supply voltage is too low.

EEPROM data corruption can easily be avoided by following this design recommendation:

Keep the AVR RESET active (low) during periods of insufficient power supply voltage. This can be done by enabling the internal Brown-out Detector (BOD). If the detection level of the internal BOD does not match the needed detection level, an external low  $V_{CC}$  reset Protection circuit can be used. If a reset occurs while a write operation is in progress, the write operation will be completed provided that the power supply voltage is sufficient.



The capacitance (Ce +Ci) needed at each TOSC pin can be calculated by using:

$$C = 2 \cdot CL - C_s$$

where:

- Ce is optional external capacitors as described in Figure 8-2 on page29
- Ci is the pin capacitance in table 8-8 on page 33
- CL is the load capacitance for a 32.768 kHz crystal specified by the crystal vendor
- CS is the total stray capacitance for one TOSC pin.

Crystals specifying load capacitance (CL) higher than 8.0 pF, require external capacitors applied as described in Figure 6-2 on page 31.

When this oscillator is selected, start-up times are determined by the SUT Fuses and CKSEL0 as shown in Table 6-9.

| Power Conditions    | Start-up Time from<br>Power-down and<br>Power-save | Additional Delay<br>from Reset<br>(V <sub>CC</sub> = 5.0V) | CKSEL0 | SUT10 |  |  |
|---------------------|----------------------------------------------------|------------------------------------------------------------|--------|-------|--|--|
| BOD enabled         | 1K CK                                              | 14CK <sup>(1)</sup>                                        | 0      | 00    |  |  |
| Fast rising power   | 1K CK                                              | 14CK + 4.1 ms <sup>(1)</sup>                               | 0      | 01    |  |  |
| Slowly rising power | 1K CK                                              | 14CK + 65 ms <sup>(1)</sup>                                | 0      | 10    |  |  |
|                     | Reserved                                           |                                                            | 0      | 11    |  |  |
| BOD enabled         | 32K CK                                             | 14CK                                                       | 1      | 00    |  |  |
| Fast rising power   | 32K CK                                             | 14CK + 4.1 ms                                              | 1      | 01    |  |  |
| Slowly rising power | 32K CK                                             | 14CK + 65 ms                                               | 1      | 10    |  |  |
|                     | Reserved                                           |                                                            |        |       |  |  |

 Table 6-9.
 Start-up Times for the Low Frequency Crystal Oscillator Clock Selection

Note: 1. These options should only be used if frequency stability at start-up is not important for the application.



# 8.7 Internal Voltage Reference

ATmega164P/324P/644P features an internal bandgap reference. This reference is used for Brown-out Detection, and it can be used as an input to the Analog Comparator or the ADC.

## 8.7.1 Voltage Reference Enable Signals and Start-up Time

The voltage reference has a start-up time that may influence the way it should be used. The start-up time is given in "System and Reset Characteristics" on page 331. To save power, the reference is not always turned on. The reference is on during the following situations:

- 1. When the BOD is enabled (by programming the BODLEVEL [2:0] Fuse).
- 2. When the bandgap reference is connected to the Analog Comparator (by setting the ACBG bit in ACSR).
- 3. When the ADC is enabled.

Thus, when the BOD is not enabled, after setting the ACBG bit or enabling the ADC, the user must always allow the reference to start up before the output from the Analog Comparator or ADC is used. To reduce power consumption in Power-down mode, the user can avoid the three conditions above to ensure that the reference is turned off before entering Power-down mode.



Figure 12-5. CTC Mode, Timing Diagram



An interrupt can be generated each time the counter value reaches the TOP value by using the OCF0A Flag. If the interrupt is enabled, the interrupt handler routine can be used for updating the TOP value. However, changing TOP to a value close to BOTTOM when the counter is running with none or a low prescaler value must be done with care since the CTC mode does not have the double buffering feature. If the new value written to OCR0A is lower than the current value of TCNT0, the counter will miss the Compare Match. The counter will then have to count to its maximum value (0xFF) and wrap around starting at 0x00 before the Compare Match can occur.

For generating a waveform output in CTC mode, the OC0A output can be set to toggle its logical level on each Compare Match by setting the Compare Output mode bits to toggle mode (COM0A1:0 = 1). The OC0A value will not be visible on the port pin unless the data direction for the pin is set to output. The waveform generated will have a maximum frequency of  $f_{OC0} = f_{clk\_l/O}/2$  when OCR0A is set to zero (0x00). The waveform frequency is defined by the following equation:

$$f_{OCnx} = \frac{f_{\mathsf{clk\_I/O}}}{2 \cdot N \cdot (1 + OCRnx)}$$

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

As for the Normal mode of operation, the TOV0 Flag is set in the same timer clock cycle that the counter counts from MAX to 0x00.

#### 12.7.3 Fast PWM Mode

The fast Pulse Width Modulation or fast PWM mode (WGM02:0 = 3 or 7) provides a high frequency PWM waveform generation option. The fast PWM differs from the other PWM option by its single-slope operation. The counter counts from BOTTOM to TOP then restarts from BOT-TOM. TOP is defined as 0xFF when WGM2:0 = 3, and OCR0A when WGM2:0 = 7. In noninverting Compare Output mode, the Output Compare (OC0x) is cleared on the Compare Match between TCNT0 and OCR0x, and set at BOTTOM. In inverting Compare Output mode, the output is set on Compare Match and cleared at BOTTOM. Due to the single-slope operation, the operating frequency of the fast PWM mode can be twice as high as the phase correct PWM mode that use dual-slope operation. This high frequency makes the fast PWM mode well suited for power regulation, rectification, and DAC applications. High frequency allows physically small sized external components (coils, capacitors), and therefore reduces total system cost.

In fast PWM mode, the counter is incremented until the counter value matches the TOP value. The counter is then cleared at the following timer clock cycle. The timing diagram for the fast



When the ICRn is used as TOP value (see description of the WGMn3:0 bits located in the TCCRnA and the TCCRnB Register), the ICPn 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 TCCRnB is written.

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

See TCCRnA Register description.

#### • Bit 2:0 - CSn2:0: Clock Select

The three Clock Select bits select the clock source to be used by the Timer/Counter, see Figure 13-10 and Figure 13-11.

| CSn2 | CSn1 | CSn0 | 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 Tn pin. Clock on falling edge. |
| 1    | 1    | 1    | External clock source on Tn pin. Clock on rising edge.  |

Table 13-6. Clock Select Bit Description

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

#### 13.11.3 TCCR1C – Timer/Counter1 Control Register C



#### • Bit 7 – FOCnA: Force Output Compare for Channel A

#### • Bit 6 – FOCnB: Force Output Compare for Channel B

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







The frame format used by the USART is set by the UCSZn2:0, UPMn1:0 and USBSn bits in UCSRnB and UCSRnC. 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.

The USART Character SiZe (UCSZn2:0) bits select the number of data bits in the frame. The USART Parity mode (UPMn1:0) bits enable and set the type of parity bit. The selection between one or two stop bits is done by the USART Stop Bit Select (USBSn) bit. The Receiver ignores the second stop bit. An FE (Frame Error) will therefore only be detected in the cases where the first stop bit is zero.

#### 16.5.1 Parity Bit Calculation

The parity bit is calculated by doing an exclusive-or of all the data bits. If odd parity is used, the result of the exclusive or is inverted. The relation between the parity bit and data bits is as follows::

 $\begin{array}{l} P_{even} = d_{n-1} \oplus \ldots \oplus d_3 \oplus d_2 \oplus d_1 \oplus d_0 \oplus 0 \\ P_{odd} = d_{n-1} \oplus \ldots \oplus d_3 \oplus d_2 \oplus d_1 \oplus d_0 \oplus 1 \end{array}$ 

| P <sub>even</sub> | Parity bit using even parity |
|-------------------|------------------------------|
| P <sub>odd</sub>  | Parity bit using odd parity  |
| d <sub>n</sub>    | Data bit n of the character  |

If used, the parity bit is located between the last data bit and first stop bit of a serial frame.

## 16.6 USART Initialization

The USART has to be initialized before any communication can take place. The initialization process normally consists of setting the baud rate, setting frame format and enabling the Transmitter or the Receiver depending on the usage. For interrupt driven USART operation, the Global Interrupt Flag should be cleared and the USART interrupts should be disabled.

Before doing a re-initialization with changed baud rate or frame format, be sure that there are 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 RXC Flag can be used to



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

```
USART_Transmit:
```

; Wait for empty transmit buffer **sbis** UCSRnA,UDREn

```
rjmp USART_Transmit
; Copy 9th bit from r17 to TXB8
```

```
cbi UCSRnB, TXB8
```

sbrc r17,0
sbi UCSRnB,TXB8
; Put LSB data (r16) into buffer, sends the data

```
out UDRn,r16
```

C Code Example<sup>(1)(2)</sup>

```
void USART_Transmit( unsigned int data )
{
    /* Wait for empty transmit buffer */
    while ( !( UCSRnA & (1<<UDREn))) )
      ;
    /* Copy 9th bit to TXB8 */
    UCSRnB &= ~(1<<TXB8);
    if ( data & 0x0100 )
      UCSRnB |= (1<<TXB8);
    /* Put data into buffer, sends the data */
    UDRn = data;
}</pre>
```

- Notes: 1. These transmit functions are written to be general functions. They can be optimized if the contents of the UCSRnB is static. For example, only the TXB8 bit of the UCSRnB Register is used after initialization.
  - 2. See "About Code Examples" on page 8.

The ninth bit can be used for indicating an address frame when using multi processor communication mode or for other protocol handling as for example synchronization.

# 16.7.3 Transmitter Flags and Interrupts

The USART Transmitter has two flags that indicate its state: USART Data Register Empty (UDREn) and Transmit Complete (TXCn). Both flags can be used for generating interrupts.

The Data Register Empty (UDREn) Flag indicates whether the transmit buffer is ready to receive new data. This bit is set when the transmit buffer is empty, and cleared when the transmit buffer contains data to be transmitted that has not yet been moved into the Shift Register. For compatibility with future devices, always write this bit to zero when writing the UCSRnA Register.

When the Data Register Empty Interrupt Enable (UDRIEn) bit in UCSRnB is written to one, the USART Data Register Empty Interrupt will be executed as long as UDREn is set (provided that global interrupts are enabled). UDREn is cleared by writing UDRn. When interrupt-driven data



# 18.5 Overview of the TWI Module

The TWI module is comprised of several submodules, as shown in Figure 18-9. All registers drawn in a thick line are accessible through the AVR data bus.



Figure 18-9. Overview of the TWI Module

#### 18.5.1 SCL and SDA Pins

These pins interface the AVR TWI with the rest of the MCU system. The output drivers contain a slew-rate limiter in order to conform to the TWI specification. The input stages contain a spike suppression unit removing spikes shorter than 50 ns. Note that the internal pull-ups in the AVR pads can be enabled by setting the PORT bits corresponding to the SCL and SDA pins, as explained in the I/O Port section. The internal pull-ups can in some systems eliminate the need for external ones.

#### 18.5.2 Bit Rate Generator Unit

This unit controls the period of SCL when operating in a Master mode. The SCL period is controlled by settings in the TWI Bit Rate Register (TWBR) and the Prescaler bits in the TWI Status Register (TWSR). Slave operation does not depend on Bit Rate or Prescaler settings, but the CPU clock frequency in the Slave must be at least 16 times higher than the SCL frequency. Note that slaves may prolong the SCL low period, thereby reducing the average TWI bus clock period. The SCL frequency is generated according to the following equation:



# ATmega164P/324P/644P

Example:

ADMUX = 0xED (ADC3 - ADC2, 10x gain, 2.56V reference, left adjusted result)

Voltage on ADC3 is 300 mV, voltage on ADC2 is 500 mV.

ADCR = 512 \* 10 \* (300 - 500) / 2560 = -400 = 0x270

ADCL will thus read 0x00, and ADCH will read 0x9C. Writing zero to ADLAR right adjusts the result: ADCL = 0x70, ADCH = 0x02.

## 20.9 Register Description

### 20.9.1 ADMUX – ADC Multiplexer Selection Register

| Bit           | 7     | 6     | 5     | 4    | 3    | 2    | 1    | 0    |       |
|---------------|-------|-------|-------|------|------|------|------|------|-------|
| (0x7C)        | REFS1 | REFS0 | ADLAR | MUX4 | MUX3 | MUX2 | MUX1 | MUX0 | ADMUX |
| 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:6 – REFS1:0: Reference Selection Bits

These bits select the voltage reference for the ADC, as shown in Table 20-3. If these bits are changed during a conversion, the change will not go in effect until this conversion is complete (ADIF in ADCSRA is set). The internal voltage reference options may not be used if an external reference voltage is being applied to the AREF pin.

Table 20-3. Voltage Reference Selections for ADC

| REFS1 | REFS0 | Voltage Reference Selection                                          |
|-------|-------|----------------------------------------------------------------------|
| 0     | 0     | AREF, Internal Vref turned off                                       |
| 0     | 1     | AVCC with external capacitor at AREF pin                             |
| 1     | 0     | Internal 1.1V Voltage Reference with external capacitor at AREF pin  |
| 1     | 1     | Internal 2.56V Voltage Reference with external capacitor at AREF pin |

Note: If 10x og 200x gain is selected, only 2.56V should be used as Internal Voltage Reference.

#### Bit 5 – ADLAR: ADC Left Adjust Result

The ADLAR bit affects the presentation of the ADC conversion result in the ADC Data Register. Write one to ADLAR to left adjust the result. Otherwise, the result is right adjusted. Changing the ADLAR bit will affect the ADC Data Register immediately, regardless of any ongoing conversions. For a complete description of this bit, see "ADCL and ADCH – The ADC Data Register" on page 258.

#### • Bits 4:0 – MUX4:0: Analog Channel and Gain Selection Bits

The value of these bits selects which combination of analog inputs are connected to the ADC. These bits also select the gain for the differential channels. See Table 20-4 on page 256 for details. If these bits are changed during a conversion, the change will not go in effect until this conversion is complete (ADIF in ADCSRA is set).



The JTAG programming capability supports:

- Flash programming and verifying.
- EEPROM programming and verifying.
- Fuse programming and verifying.
- Lock bit programming and verifying.

The Lock bit security is exactly as in parallel programming mode. If the Lock bits LB1 or LB2 are programmed, the OCDEN Fuse cannot be programmed unless first doing a chip erase. This is a security feature that ensures no back-door exists for reading out the content of a secured device.

The details on programming through the JTAG interface and programming specific JTAG instructions are given in the section "Programming via the JTAG Interface" on page 312.

# 21.9 Bibliography

For more information about general Boundary-scan, the following literature can be consulted:

- IEEE: IEEE Std. 1149.1-1990. IEEE Standard Test Access Port and Boundary-scan Architecture, IEEE, 1993.
- Colin Maunder: The Board Designers Guide to Testable Logic Circuits, Addison-Wesley, 1992.

## 21.10 Register Description

#### 21.10.1 OCDR – On-chip Debug Register



The OCDR Register provides a communication channel from the running program in the microcontroller to the debugger. The CPU can transfer a byte to the debugger by writing to this location. At the same time, an internal flag; I/O Debug Register Dirty – IDRD – is set to indicate to the debugger that the register has been written. When the CPU reads the OCDR Register the 7 LSB will be from the OCDR Register, while the MSB is the IDRD bit. The debugger clears the IDRD bit when it has read the information.

In some AVR devices, this register is shared with a standard I/O location. In this case, the OCDR Register can only be accessed if the OCDEN Fuse is programmed, and the debugger enables access to the OCDR Register. In all other cases, the standard I/O location is accessed.

Refer to the debugger documentation for further information on how to use this register.



| BLB0 Mode | BLB02 | BLB01 | Protection                                                                                                                                                                                                                                                                                                   |
|-----------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1         | 1     | 1     | No restrictions for SPM or (E)LPM accessing the Application section.                                                                                                                                                                                                                                         |
| 2         | 1     | 0     | SPM is not allowed to write to the Application section.                                                                                                                                                                                                                                                      |
| 3         | 0     | 0     | SPM is not allowed to write to the Application section, and<br>(E)LPM executing from the Boot Loader section is not allowed to<br>read from the Application section. If Interrupt Vectors are placed<br>in the Boot Loader section, interrupts are disabled while<br>executing from the Application section. |
| 4         | 0     | 1     | (E)LPM executing from the Boot Loader section is not allowed to<br>read from the Application section. If Interrupt Vectors are placed<br>in the Boot Loader section, interrupts are disabled while<br>executing from the Application section.                                                                |

| Table 23-2. | Boot Lock Bit0 Protection Modes | (Application Section) | (1) |
|-------------|---------------------------------|-----------------------|-----|
|             |                                 |                       |     |

Note: 1. "1" means unprogrammed, "0" means programmed

| BLB1 Mode | BLB12 | BLB11 | Protection                                                                                                                                                                                                                                                                                                   |
|-----------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1         | 1     | 1     | No restrictions for SPM or (E)LPM accessing the Boot Loader section.                                                                                                                                                                                                                                         |
| 2         | 1     | 0     | SPM is not allowed to write to the Boot Loader section.                                                                                                                                                                                                                                                      |
| 3         | 0     | 0     | SPM is not allowed to write to the Boot Loader section, and<br>(E)LPM executing from the Application section is not allowed to<br>read from the Boot Loader section. If Interrupt Vectors are<br>placed in the Application section, interrupts are disabled while<br>executing from the Boot Loader section. |
| 4         | 0     | 1     | (E)LPM executing from the Application section is not allowed to<br>read from the Boot Loader section. If Interrupt Vectors are<br>placed in the Application section, interrupts are disabled while<br>executing from the Boot Loader section.                                                                |

| Table 23-3. | Boot Lock Bit1 Protection Modes | (Boot Loader Section) <sup>(1</sup> |
|-------------|---------------------------------|-------------------------------------|
|             |                                 |                                     |

Note: 1. "1" means unprogrammed, "0" means programmed

# 23.6 Entering the Boot Loader Program

Entering the Boot Loader takes place by a jump or call from the application program. This may be initiated by a trigger such as a command received via USART, or SPI interface. Alternatively, the Boot Reset Fuse can be programmed so that the Reset Vector is pointing to the Boot Flash start address after a reset. In this case, the Boot Loader is started after a reset. After the application code is loaded, the program can start executing the application code. Note that the fuses cannot be changed by the MCU itself. This means that once the Boot Reset Fuse is programmed, the Reset Vector will always point to the Boot Loader Reset and the fuse can only be changed through the serial or parallel programming interface.

Table 23-4. Boot Reset Fuse<sup>(1)</sup>

| BOOTRST | Reset Address                                                 |
|---------|---------------------------------------------------------------|
| 1       | Reset Vector = Application Reset (address 0x0000)             |
| 0       | Reset Vector = Boot Loader Reset (see Table 23-7 on page 288) |

Note: 1. "1" means unprogrammed, "0" means programmed



is recommended that the user checks the status bit (EEPE) in the EECR Register and verifies that the bit is cleared before writing to the SPMCSR Register.

#### 23.8.9 Reading the Fuse and Lock Bits from Software

It is possible to read both the Fuse and Lock bits from software. To read the Lock bits, load the Z-pointer with 0x0001 and set the BLBSET and SPMEN bits in SPMCSR. When an (E)LPM instruction is executed within three CPU cycles after the BLBSET and SPMEN bits are set in SPMCSR, the value of the Lock bits will be loaded in the destination register. The BLBSET and SPMEN bits will auto-clear upon completion of reading the Lock bits or if no (E)LPM instruction is executed within three CPU cycles or no SPM instruction is executed within four CPU cycles. When BLBSET and SPMEN are cleared, (E)LPM will work as described in the Instruction set Manual.



The algorithm for reading the Fuse Low byte is similar to the one described above for reading the Lock bits. To read the Fuse Low byte, load the Z-pointer with 0x0000 and set the BLBSET and SPMEN bits in SPMCSR. When an (E)LPM instruction is executed within three cycles after the BLBSET and SPMEN bits are set in the SPMCSR, the value of the Fuse Low byte (FLB) will be loaded in the destination register as shown below. Refer to Table 24-5 on page 295 for a detailed description and mapping of the Fuse Low byte.

Similarly, when reading the Fuse High byte, load 0x0003 in the Z-pointer. When an (E)LPM instruction is executed within three cycles after the BLBSET and SPMEN bits are set in the SPMCSR, the value of the Fuse High byte (FHB) will be loaded in the destination register as shown below. Refer to Table 24-4 on page 295 for detailed description and mapping of the Fuse High byte.



When reading the Extended Fuse byte, load 0x0002 in the Z-pointer. When an (E)LPM instruction is executed within three cycles after the BLBSET and SPMEN bits are set in the SPMCSR, the value of the Extended Fuse byte (EFB) will be loaded in the destination register as shown below. Refer to Table 24-3 on page 294 for detailed description and mapping of the Extended Fuse byte.



Fuse and Lock bits that are programmed, will be read as zero. Fuse and Lock bits that are unprogrammed, will be read as one.

#### 23.8.10 Reading the Signature Row from Software

To read the Signature Row from software, load the Z-pointer with the signature byte address given in Table 23-5 on page 285 and set the SIGRD and SPMEN bits in SPMCSR. When an LPM instruction is executed within three CPU cycles after the SIGRD and SPMEN bits are set in SPMCSR, the signature byte value will be loaded in the destination register. The SIGRD and SPMEN bits will auto-clear upon completion of reading the Signature Row Lock bits or if no LPM



# 23.8.16 ATmega644P Boot Loader Parameters

In Table 23-13 through Table 23-15, the parameters used in the description of the Self-Programming are given.

| Table 23-13. | Boot Size Configuration <sup>(1)</sup> |
|--------------|----------------------------------------|
|--------------|----------------------------------------|

| BOOTSZ1 | BOOTSZ0 | Boot Size  | Pages | Application<br>Flash Section | Boot Loader<br>Flash Section | End Application<br>Section | Boot Reset<br>Address<br>(Start Boot<br>Loader Section) |
|---------|---------|------------|-------|------------------------------|------------------------------|----------------------------|---------------------------------------------------------|
| 1       | 1       | 512 words  | 4     | 0x0000 - 0x7DFF              | 0x7E00 - 0x7FFF              | 0x7DFF                     | 0x7E00                                                  |
| 1       | 0       | 1024 words | 8     | 0x0000 - 0x7BFF              | 0x7C00 - 0x7FFF              | 0x7BFF                     | 0x7C00                                                  |
| 0       | 1       | 2048 words | 16    | 0x0000 - 0x77FF              | 0x7800 - 0x7FFF              | 0x77FF                     | 0x7800                                                  |
| 0       | 0       | 4096 words | 32    | 0x0000 - 0x6FFF              | 0x7000 - 0x7FFF              | 0x6FFF                     | 0x7000                                                  |

Note: 1. The different BOOTSZ Fuse configurations are shown in Figure 23-2 on page 279.

# Table 23-14. Read-While-Write Limit<sup>(1)</sup>

| Section                            | Pages | Address         |
|------------------------------------|-------|-----------------|
| Read-While-Write section (RWW)     | 224   | 0x0000 - 0x6FFF |
| No Read-While-Write section (NRWW) | 32    | 0xF000 - 0x7FFF |

Note: 1. For details about these two section, see "NRWW – No Read-While-Write Section" on page 277 and "RWW – Read-While-Write Section" on page 277.

## Table 23-15.

Explanation of different variables used in Figure 23-3 on page 281 and the mapping to the Z-pointer

| Variable |          | Correspondi<br>ng<br>Z-value | Description <sup>(1)</sup>                                                                                                  |
|----------|----------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| PCMSB    | 14       |                              | Most significant bit in the Program Counter. (The Program Counter is 15 bits PC[14:0])                                      |
| PAGEMSB  | 7        |                              | Most significant bit which is used to address the words within one page (128 words in a page requires seven bits PC [6:0]). |
| ZPCMSB   |          | Z15                          | Bit in Z-pointer that is mapped to PCMSB. Because Z0 is not used, the ZPCMSB equals PCMSB + 1.                              |
| ZPAGEMSB |          | Z8                           | Bit in Z-pointer that is mapped to PCMSB. Because Z0 is not used, the ZPAGEMSB equals PAGEMSB + 1.                          |
| PCPAGE   | PC[14:7] | Z15:Z7                       | Program Counter page address: Page select, for Page Erase and Page Write                                                    |
| PCWORD   | PC[6:0]  | Z7:Z1                        | Program Counter word address: Word select, for filling temporary buffer (must be zero during Page Write operation)          |

Note: 1. Z0: should be zero for all SPM commands, byte select for the (E)LPM instruction.

See "Addressing the Flash During Self-Programming" on page 281 for details about the use of Z-pointer during Self-Programming.



### 24.9.1 Serial Programming Characteristics

For characteristics of the Serial Programming module see "SPI Timing Characteristics" on page 332.



#### Figure 24-12. Serial Programming Waveforms

## 24.10 Programming via the JTAG Interface

Programming through the JTAG interface requires control of the four JTAG specific pins: TCK, TMS, TDI, and TDO. Control of the reset and clock pins is not required.

To be able to use the JTAG interface, the JTAGEN Fuse must be programmed. The device is default shipped with the fuse programmed. In addition, the JTD bit in MCUCR must be cleared. Alternatively, if the JTD bit is set, the external reset can be forced low. Then, the JTD bit will be cleared after two chip clocks, and the JTAG pins are available for programming. This provides a means of using the JTAG pins as normal port pins in Running mode while still allowing In-System Programming via the JTAG interface. Note that this technique can not be used when using the JTAG pins for Boundary-scan or On-chip Debug. In these cases the JTAG pins must be dedicated for this purpose.

During programming the clock frequency of the TCK Input must be less than the maximum frequency of the chip. The System Clock Prescaler can not be used to divide the TCK Clock Input into a sufficiently low frequency.

As a definition in this datasheet, the LSB is shifted in and out first of all Shift Registers.

#### 24.10.1 Programming Specific JTAG Instructions

The Instruction Register is 4-bit wide, supporting up to 16 instructions. The JTAG instructions useful for programming are listed below.

The OPCODE for each instruction is shown behind the instruction name in hex format. The text describes which Data Register is selected as path between TDI and TDO for each instruction.

The Run-Test/Idle state of the TAP controller is used to generate internal clocks. It can also be used as an idle state between JTAG sequences. The state machine sequence for changing the instruction word is shown in Figure 24-13 on page 313.



Table 24-18. JTAG Programming Instruction

Set **a** = address high bits, **b** = address low bits, **c** = address extended bits, **H** = 0 - Low byte, 1 - High Byte, **o** = data out, **i** = data in, x = don't care

| Instruction                         | TDI Sequence                                                               | TDO Sequence                                        | Notes                 |
|-------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------|-----------------------|
| 1a. Chip Erase                      | 0100011_1000000<br>0110001_1000000<br>0110011_10000000<br>0110011_10000000 | XXXXXXX_XXXXXX<br>XXXXXXX_XXXXXXX<br>XXXXXXX_XXXXXX |                       |
| 1b. Poll for Chip Erase Complete    | 0110011_10000000                                                           | XXXXXOX_XXXXXXX                                     | (2)                   |
| 2a. Enter Flash Write               | 0100011_00010000                                                           | XXXXXXX_XXXXXXX                                     |                       |
| 2b. Load Address Extended High Byte | 0001011_cccccccc                                                           | xxxxxxx_xxxxxxx                                     | (10)                  |
| 2c. Load Address High Byte          | 0000111_aaaaaaaa                                                           | XXXXXXX_XXXXXXX                                     |                       |
| 2d. Load Address Low Byte           | 0000011_bbbbbbbb                                                           | xxxxxxx_xxxxxx                                      |                       |
| 2e. Load Data Low Byte              | 0010011_iiiiiiiii                                                          | xxxxxxx_xxxxxxx                                     |                       |
| 2f. Load Data High Byte             | 0010111_iiiiiiiii                                                          | xxxxxxx_xxxxxxx                                     |                       |
| 2g. Latch Data                      | 0110111_00000000<br>1110111_00000000<br>0110111_00000000                   | XXXXXXX_XXXXXXX<br>XXXXXXX_XXXXXXXX<br>XXXXXXX      | (1)                   |
| 2h. Write Flash Page                | 0110111_00000000<br>0110101_00000000<br>0110111_00000000                   | xxxxxxx_xxxxxxx<br>xxxxxxx_xxxxxxxx<br>xxxxxxx      | (1)                   |
| 2i. Poll for Page Write Complete    | 0110111_00000000                                                           | XXXXXOX_XXXXXXX                                     | (2)                   |
| 3a. Enter Flash Read                | 0100011_00000010                                                           | XXXXXXX_XXXXXXX                                     |                       |
| 3b. Load Address Extended High Byte | 0001011_cccccccc                                                           | XXXXXXX_XXXXXXX                                     | (10)                  |
| 3c. Load Address High Byte          | 0000111_aaaaaaaa                                                           | XXXXXXX_XXXXXXX                                     |                       |
| 3d. Load Address Low Byte           | 0000011_bbbbbbbb                                                           | xxxxxxx_xxxxxxx                                     |                       |
| 3e. Read Data Low and High Byte     | 0110010_0000000<br>0110110_00000000<br>0110111_00000000                    | XXXXXXX_XXXXXXX<br>XXXXXXX_00000000<br>XXXXXXXX     | Low byte<br>High byte |
| 4a. Enter EEPROM Write              | 0100011_00010001                                                           | XXXXXXX_XXXXXXX                                     |                       |
| 4b. Load Address High Byte          | 0000111_aaaaaaaa                                                           | xxxxxxx_xxxxxxx                                     | (10)                  |
| 4c. Load Address Low Byte           | 0000011_bbbbbbbb                                                           | xxxxxxx_xxxxxxx                                     |                       |
| 4d. Load Data Byte                  | 0010011_iiiiiiii                                                           | XXXXXXX_XXXXXXX                                     |                       |
| 4e. Latch Data                      | 0110111_00000000<br>1110111_00000000<br>0110111_00000000                   | XXXXXXX_XXXXXXX<br>XXXXXXX_XXXXXXXX<br>XXXXXXX      | (1)                   |
| 4f. Write EEPROM Page               | 0110011_0000000<br>0110001_0000000<br>0110011_00000000                     | XXXXXXX_XXXXXX<br>XXXXXXX_XXXXXXX<br>XXXXXXX_XXXXXX | (1)                   |
| 4g. Poll for Page Write Complete    | 0110011_00000000                                                           | XXXXXOX_XXXXXXX                                     | (2)                   |



- 6. Load data low byte using programming instructions 6e. A "0" will program the fuse, a "1" will unprogram the fuse.
- 7. Write Fuse low byte using programming instruction 6f.
- 8. Poll for Fuse write complete using programming instruction 6g, or wait for t<sub>WLRH</sub> (refer to Table 24-14 on page 306).

## 24.10.21 Programming the Lock Bits

- 1. Enter JTAG instruction PROG\_COMMANDS.
- 2. Enable Lock bit write using programming instruction 7a.
- 3. Load data using programming instructions 7b. A bit value of "0" will program the corresponding lock bit, a "1" will leave the lock bit unchanged.
- 4. Write Lock bits using programming instruction 7c.
- 5. Poll for Lock bit write complete using programming instruction 7d, or wait for t<sub>WLRH</sub> (refer to Table 24-14 on page 306).

## 24.10.22 Reading the Fuses and Lock Bits

- 1. Enter JTAG instruction PROG\_COMMANDS.
- 2. Enable Fuse/Lock bit read using programming instruction 8a.
- To read all Fuses and Lock bits, use programming instruction 8e. To only read Fuse High byte, use programming instruction 8b. To only read Fuse Low byte, use programming instruction 8c. To only read Lock bits, use programming instruction 8d.

## 24.10.23 Reading the Signature Bytes

- 1. Enter JTAG instruction PROG\_COMMANDS.
- 2. Enable Signature byte read using programming instruction 9a.
- 3. Load address 0x00 using programming instruction 9b.
- 4. Read first signature byte using programming instruction 9c.
- 5. Repeat steps 3 and 4 with address 0x01 and address 0x02 to read the second and third signature bytes, respectively.

## 24.10.24 Reading the Calibration Byte

- 1. Enter JTAG instruction PROG\_COMMANDS.
- 2. Enable Calibration byte read using programming instruction 10a.
- 3. Load address 0x00 using programming instruction 10b.
- 4. Read the calibration byte using programming instruction 10c.



| PRR bit  | Additional Current consumption<br>compared to Active with external<br>clock (see Figure 26-1 on page<br>338 and Figure 26-2 on page 339) | Additional Current consumption<br>compared to Idle with external<br>clock (see Figure 26-6 on page<br>341 and Figure 26-7 on page 341) |
|----------|------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| PRUSART1 | 1.8%                                                                                                                                     | 6.9%                                                                                                                                   |
| PRUSART0 | 2.4%                                                                                                                                     | 9.1%                                                                                                                                   |
| PRTWI    | 5.4%                                                                                                                                     | 21.2%                                                                                                                                  |
| PRTIM2   | 4.6%                                                                                                                                     | 17.4%                                                                                                                                  |
| PRTIM1   | 2.7%                                                                                                                                     | 10.5%                                                                                                                                  |
| PRTIM0   | 1.6%                                                                                                                                     | 6.0%                                                                                                                                   |
| PRADC    | 4.5%                                                                                                                                     | 16.8%                                                                                                                                  |
| PRSPI    | 3.3%                                                                                                                                     | 12.9%                                                                                                                                  |

| Table 26-2. | Additional Current | Consumption ( | (percentage) | ) in Acti | ive and | Idle mode |
|-------------|--------------------|---------------|--------------|-----------|---------|-----------|
|-------------|--------------------|---------------|--------------|-----------|---------|-----------|

It is possible to calculate the typical current consumption based on the numbers from Table 26-2 on page 344 for other  $V_{CC}$  and frequency settings than listed in Table 26-1 on page 343.

ExampleCalculate the expected current consumption in idle mode with TIMER1, ADC, and SPI enabled<br/>at  $V_{CC} = 2.0V$  and F = 1MHz. From Table 26-2 on page 344, third column, we see that we need<br/>to add 10.5% for the TIMER1, 16.8% for the ADC, and 12.9% for the SPI module. Reading<br/>from Figure 26-6 on page 341, we find that the idle current consumption is ~0.115 mA at  $V_{CC} =$ <br/>2.0V and F = 1MHz. The total current consumption in idle mode with TIMER1, ADC, and SPI<br/>enabled, gives:

 $\text{ICC}_{\text{total}} \approx 0.115 \ \text{mA} \cdot (1 + 0.105 + 0.168 + 0.129) \approx 0.161 \ \text{mA}$ 

#### 26.1.4 Power-down Supply Current

Figure 26-11. Power-down Supply Current vs. V<sub>CC</sub> (Watchdog Timer Disabled).







Figure 26-113. Reset Pull-up Resistor Current vs. Reset Pin Voltage ( $V_{CC} = 2.7V$ ).







## 26.3.8 Pin Driver Strength



Figure 26-115.I/O Pin Sink Current vs. Output Voltage ( $V_{CC} = 3V$ ).







| 7 | Table of Contents        | i   |
|---|--------------------------|-----|
|   | 32.14 Rev. 8011A - 08/06 | 430 |
|   | 32.13 Rev. 8011B - 09/06 | 430 |
|   | 32.12 Rev. 8011C - 10/06 | 429 |