

## 8.4 EEPROM Data Memory

The ATmega48A/PA/88A/PA/168A/PA/328/P contains 256/512/512/1Kbytes 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.

### 8.4.1 EEPROM Read/Write Access

3.3 —

The EEPROM Access Registers are accessible in the I/O space.

The write access time for the EEPROM is given in Table 8-2. 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 "Preventing EEPROM Corruption" on page 30 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.



BOD Reset

↓ write  
Read

### 8.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.

#### 8.6.1 EEARH and EEARL - The EEPROM Address Register

| Bit           | 15    | 14    | 13    | 12    | 11    | 10    | 9                    | 8                    | EEARH | EEARL |
|---------------|-------|-------|-------|-------|-------|-------|----------------------|----------------------|-------|-------|
| 0x22 (0x42)   | -     | -     | -     | -     | -     | -     | EEAR9 <sup>(1)</sup> | EEAR8 <sup>(1)</sup> |       |       |
| 0x21 (0x41)   | EEAR7 | EEAR6 | EEAR5 | EEAR4 | EEAR3 | EEAR2 | EEAR1                | EEAR0                |       |       |
| Read/Write    | R     | R     | R     | R     | R     | R     | R                    | R/W                  |       |       |
|               | R/W                  | R/W                  |       |       |
| Initial Value | 0     | 0     | 0     | 0     | 0     | 0     | 0                    | X                    |       |       |
|               | X     | X     | X     | X     | X     | X     | X                    | X                    |       |       |

- Bits [15:10] – Reserved

These bits are reserved bits in the ATmega48A/PA/88A/PA/168A/PA/328/P and will always read as zero.

- Bits 9:0 – EEAR[9:0]: EEPROM Address

The EEPROM Address Registers – EEARH and EEARL specify the EEPROM address in the 256/512/512/1Kbytes EEPROM space. The EEPROM data bytes are addressed linearly between 0 and 255/511/511/1023. The initial value of EEAR is undefined. A proper value must be written before the EEPROM may be accessed.

Note: 1. EEAR9 and EEAR8 are unused bits in ATmega 48A/48PA and must always be written to zero.

1 = 243492  
5  
2' = 1-bit  
=  
← EOD12m  
→ 0x50

#### 8.6.2 EEDR – The EEPROM Data Register

| Bit           | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   | EEDR |
|---------------|-----|-----|-----|-----|-----|-----|-----|-----|------|
| 0x20 (0x40)   | MSB |     |     |     |     |     |     | LSB |      |
| Read/Write    | R/W |      |
| Initial Value | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |      |

- Bits 7:0 – EEDR[7:0]: EEPROM Data

For the EEPROM write operation, the EEDR Register contains the data to be written to the EEPROM in the address given by the EEAR Register. For the EEPROM read operation, the EEDR contains the data read out from the EEPROM at the address given by EEAR.

### 8.6.3 EECR – The EEPROM Control Register

| Bit           | 7            | 6            | 5    | 4    | 3     | 2     | 1    | 0    |      |
|---------------|--------------|--------------|------|------|-------|-------|------|------|------|
| 0x1F (0x3F)   | <del>R</del> | <del>R</del> | EEP1 | EEP0 | EERIE | EEMPE | EEPE | EERE | EECR |
| ReadWrite     | R            | R            | R/W  | R/W  | R/W   | R/W   | R/W  | R/W  |      |
| Initial Value | 0            | 0            | X    | X    | 0     | 0     | X    | 0    |      |

- Bits 7:6 – Reserved

These bits are reserved bits in the ATmega48A/PA/88A/PA/168A/PA/328/P and will always read as zero.

- Bits 5, 4 – EEP1 and EEP0: EEPROM Programming Mode Bits

The EEPROM Programming mode bit setting defines which programming action that will be triggered when writing EEPE. It is possible to program data in one atomic operation (erase the old value and program the new value) or to split the Erase and Write operations in two different operations. The Programming times for the different modes are shown in Table 8-1. While EEPE is set, any write to EEPm will be ignored. During reset, the EEPm bits will be reset to 0b00 unless the EEPROM is busy programming.

Table 8-1. EEPROM Mode Bits

| EEP1 | EEP0 | Programming Time | Operation                                           |
|------|------|------------------|-----------------------------------------------------|
| 0    | 0    | 3.4ms            | Erase and Write in one operation (Atomic Operation) |
| 0    | 1    | 1.8ms            | Erase Only                                          |
| 1    | 0    | 1.8ms            | Write Only                                          |
| 1    | 1    | 1.8ms            | Reserved for future use                             |

- Bit 3 – EERIE: EEPROM Ready Interrupt Enable

Writing EERIE to one enables the EEPROM Ready Interrupt if the I bit in SREG is set. Writing EERIE to zero disables the interrupt. The EEPROM Ready interrupt generates a constant interrupt when EEPE is cleared. The interrupt will not be generated during EEPROM write or SPM.

- Bit 2 – EEMPE: EEPROM Master Write Enable

The EEMPE bit determines whether setting EEPE to one causes the EEPROM to be written. When EEMPE is set, setting EEPE within four clock cycles will write data to the EEPROM at the selected address. If EEMPE is zero, setting EEPE will have no effect. When EEMPE has been written to one by software, hardware clears the bit to zero after four clock cycles. See the description of the EEPE bit for an EEPROM write procedure.

- Bit 1 – EEPE: EEPROM Write Enable

The EEPROM Write Enable Signal EEPE is the write strobe to the EEPROM. When address and data are correctly set up, the EEPE bit must be written to one to write the value into the EEPROM. The EEMPE bit must be written to one before a logical one is written to EEPE, otherwise no EEPROM write takes place. The following procedure should be followed when writing the EEPROM (the order of steps 3 and 4 is not essential):

1. Wait until EEPE becomes zero.
2. Wait until SPMEN in GPMCSCR becomes zero.
3. Write new EEPROM address to EEAR (optional).
4. Write new EEPROM data to EEDR (optional).
5. Write a logical one to the EEMPE bit while writing a zero to EEPE in EECR.
6. Within four clock cycles after setting EEMPE, write a logical one to EEPE.

The EEPROM can not be programmed during a CPU write to the Flash memory. The software must check that the Flash programming is completed before initiating a new EEPROM write. Step 2 is only relevant if the software contains a Boot Loader allowing the CPU to program the Flash. If the Flash is never being updated by the CPU, step 2 can be omitted. See "Boot Loader Support – Read-While-Write Self-Programming" on page 272 for details about Boot programming.

**Caution:** An interrupt between step 5 and step 6 will make the write cycle fail, since the EEPROM Master Write Enable will time-out. If an interrupt routine accessing the EEPROM is interrupting another EEPROM access, the EEAR or EEDR Register will be modified, causing the interrupted EEPROM access to fail. It is recommended to have the Global Interrupt Flag cleared during all the steps to avoid these problems.

When the write access time has elapsed, the EEPE bit is cleared by hardware. The user software can poll this bit and wait for a zero before writing the next byte. When EEPE has been set, the CPU is halted for two cycles before the next instruction is executed.

$\oplus XFF$   
 $\rightarrow 1111 \quad 1111$

$1 \rightarrow 0$  ✓  
 $0 \rightarrow 1$  ✗  
 $\oplus X33$   
 $0101\{0101$   
 $0101\}1000$   
 $0101 \quad 0000$   
 $\oplus X30$

- Bit 0 – EERE: EEPROM Read Enable

The EEPROM Read Enable Signal EERE is the read strobe to the EEPROM. When the correct address is set up in the EEAR Register, the EERE bit must be written to a logic one to trigger the EEPROM read. The EEPROM read access takes one instruction, and the requested data is available immediately. When the EEPROM is read, the CPU is halted for four cycles before the next instruction is executed.

The user should poll the EEPE bit before starting the read operation. If a write operation is in progress, it is neither possible to read the EEPROM, nor to change the EEAR Register.

The calibrated Oscillator is used to time the EEPROM accesses. Table 8-2 lists the typical programming time for EEPROM access from the CPU.

Table 8-2. EEPROM Programming Time

| Symbol                     | Number of Calibrated RC Oscillator Cycles | Type Programming Time |
|----------------------------|-------------------------------------------|-----------------------|
| EEPROM write<br>(from CPU) | 26,368                                    | 3.3ms                 |

The following code examples show one assembly and one C function for writing to the EEPROM. The examples assume that interrupts are controlled (e.g. by disabling interrupts globally) so that no interrupts will occur during execution of these functions. The examples also assume that no Flash Boot Loader is present in the software. If such code is present, the EEPROM write function must also wait for any ongoing SPM command to finish.

s1



Memory Allocation in Structure

s1



Memory Allocation in Union



```
#include <stdio.h>
```

```
union Data {
    unsigned int value;
    unsigned char bytes[4];
};
```

```
int main() {
    union Data data;
    data.value = 0x12345678; // Assign a 32-bit value

    printf("Bytes in memory:\n");
    for (int i = 0; i < 4; i++) {
        printf("Byte %d: 0x%02X\n", i, data.bytes[i]);
    }

    return 0;
}
```

Bytes in memory:

Byte 0: 0x78  
Byte 1: 0x56  
Byte 2: 0x34  
Byte 3: 0x12

### Little Endian

- Definition: Stores the least-significant byte (LSB) of a multi-byte data type at the lowest memory address and the most-significant byte (MSB) at the highest address.

- Common Use: Often used by Intel processors and is the default for ARM processors.

### Big Endian

- Definition: Stores the most-significant byte (MSB) of a multi-byte data type at the lowest memory address with the least-significant byte (LSB) at the highest address.

- Common Use: Historically used by Motorola processors.