AVR Libc Home Page | AVR Libc Development Pages | |||
Main Page | FAQ | Library Reference | Additional Documentation | Example Projects |
#include <avr/eeprom.h>
This header file declares the interface to some simple library routines suitable for handling the data EEPROM contained in the AVR microcontrollers. The implementation uses a simple polled mode interface. Applications that require interrupt-controlled EEPROM access to ensure that no time will be wasted in spinloops will have to deploy their own implementation.
This header file declares inline functions that call the assembler subroutines directly. This prevents that the compiler generates push/pops for the call-clobbered registers. This way also a specific calling convention could be used for the eeprom routines e.g. by passing values in __tmp_reg__, eeprom addresses in X and memory addresses in Z registers. Method is optimized for code size.
Presently supported are two locations of the EEPROM register set: 0x1F,0x20,0x21 and 0x1C,0x1D,0x1E (see __EEPROM_REG_LOCATIONS__).
As these functions modify IO registers, they are known to be non-reentrant. If any of these functions are used from both, standard and interrupt context, the applications must ensure proper protection (e.g. by disabling interrupts before accessing them).
avr-libc declarations | |
#define | EEMEM __attribute__((section(".eeprom"))) |
#define | eeprom_is_ready() |
#define | eeprom_busy_wait() do {} while (!eeprom_is_ready()) |
uint8_t | eeprom_read_byte (const uint8_t *addr) |
uint16_t | eeprom_read_word (const uint16_t *addr) |
void | eeprom_read_block (void *pointer_ram, const void *pointer_eeprom, size_t n) |
void | eeprom_write_byte (uint8_t *addr, uint8_t value) |
void | eeprom_write_word (uint16_t *addr, uint16_t value) |
void | eeprom_write_block (const void *pointer_ram, void *pointer_eeprom, size_t n) |
IAR C compatibility defines | |
#define | _EEPUT(addr, val) eeprom_write_byte ((uint8_t *)(addr), (uint8_t)(val)) |
#define | _EEGET(var, addr) (var) = eeprom_read_byte ((uint8_t *)(addr)) |
Defines | |
#define | __EEPROM_REG_LOCATIONS__ 1C1D1E |
|
In order to be able to work without a requiring a multilib approach for dealing with controllers having the EEPROM registers at different positions in memory space, the eeprom functions evaluate __EEPROM_REG_LOCATIONS__: It is assumed to be defined by the device io header and contains 6 uppercase hex digits encoding the addresses of EECR,EEDR and EEAR. First two letters: EECR address. Second two letters: EEDR address. Last two letters: EEAR address. The default 1C1D1E corresponds to the register location that is valid for most controllers. The value of this define symbol is used for appending it to the base name of the assembler functions. |
|
Read a byte from EEPROM. Compatibility define for IAR C. |
|
Write a byte to EEPROM. Compatibility define for IAR C. |
|
Attribute expression causing a variable to be allocated within the .eeprom section. |
|
Loops until the eeprom is no longer busy.
|
|
|
|
Read a block of |
|
Read one byte from EEPROM address |
|
Read one 16-bit word (little endian) from EEPROM address |
|
Write a block of |
|
Write a byte |
|
Write a word |