eeprom2 2.0.0.0
Main Page

EEPROM 2 click

EEPROM2 click provides 2 Mbit (2,097,152 bits) of Electrically Erasable and Programmable Read Only Memory, organized in bytes. In other words, this Click boardâ„¢ is an EEPROM memory medium with the capacity of 256 KB. The used EEPROM module has an impressive endurance of 4,000,000 write cycles and data retention period of over 200 years.

click Product page


Click library

  • Author : MikroE Team
  • Date : Dec 2019.
  • Type : SPI type

Software Support

We provide a library for the Eeprom2 Click as well as a demo application (example), developed using MikroElektronika compilers. The demo can run on all the main MikroElektronika development boards.

Package can be downloaded/installed directly form compilers IDE(recommended way), or downloaded from our LibStock, or found on mikroE github account.

Library Description

‍This library contains API for Eeprom2 Click driver.

Standard key functions :

Example key functions :

  • eeprom2_write This function writes a single byte of data to the given memory address.
    void eeprom2_write ( eeprom2_t *ctx, uint32_t memory_address, uint8_t value );
    void eeprom2_write(eeprom2_t *ctx, uint32_t memory_address, uint8_t value)
    Generic write function.
  • eeprom2_write_bytes This function writes bytes of data to the given memory address.
    void eeprom2_write_bytes( eeprom2_t *ctx, uint32_t memory_address, uint8_t *value, uint8_t count );
    void eeprom2_write_bytes(eeprom2_t *ctx, uint32_t memory_address, uint8_t *value, uint8_t count)
    Function to write bytes.
  • eeprom2_read_bytes This function reads bytes from the given memory address.
    void eeprom2_read_bytes( eeprom2_t *ctx, uint32_t memory_address, uint8_t *value, uint8_t count );
    void eeprom2_read_bytes(eeprom2_t *ctx, uint32_t memory_address, uint8_t *value, uint8_t count)
    Function to read bytes.

Examples Description

‍This example demonstrates the process of writing and reading of data from EEPROM.

The demo application is composed of two sections :

Application Init

‍Initializes EEPROM 2 driver.

void application_init ( void )
{
log_cfg_t log_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, "---- Application Init ----" );
// Click initialization.
EEPROM2_MAP_MIKROBUS( cfg, MIKROBUS_1 );
eeprom2_init( &eeprom2, &cfg );
}
#define EEPROM2_MAP_MIKROBUS(cfg, mikrobus)
Definition eeprom2.h:67
void application_init(void)
Definition main.c:35

Application Task

‍Writing data to EEPROM and then reading that data and writing it via UART.

void application_task ( void )
{
eeprom2_write_bytes ( &eeprom2, 0x01, text, 6 );
log_printf ( &logger, "Writing Mikroe to EEPROM 2 click\r\n" );
Delay_ms ( 1000 );
eeprom2_read_bytes ( &eeprom2, 0x01 , mem_value, 6 );
log_printf ( &logger, "Data read: %s\r\n", mem_value );
Delay_ms ( 1000 );
}
void application_task(void)
Definition main.c:59
uint8_t text[7]
Definition main.c:30
uint8_t mem_value[7]
Definition main.c:31

The full application code, and ready to use projects can be installed directly form compilers IDE(recommneded) or found on LibStock page or mikroE GitHub accaunt.

Other mikroE Libraries used in the example:

  • MikroSDK.Board
  • MikroSDK.Log
  • Click.Eeprom2

Additional notes and informations

Depending on the development board you are using, you may need USB UART click, USB UART 2 Click or RS232 Click to connect to your PC, for development systems with no UART to USB interface available on the board. The terminal available in all Mikroelektronika compilers, or any other terminal application of your choice, can be used to read the message.