Andy Little / I2CEeprom

Dependents:   storage_test

Embed: (wiki syntax)

« Back to documentation index

I2CEeprom Class Reference

I2CEeprom Class Reference

Based on the original Mbed I2CEeprom library by Robin Hourahane. More...

#include <I2CEeprom.h>

Public Member Functions

 I2CEeprom (I2C &i2c, int address, size_t pageSize, size_t chipSize, uint8_t writeCycleTime_ms)
 Constructor to create a new instance of the class.
size_t read (size_t address, char &value)
 Read a single byte from the EEprom.
size_t read (size_t address, char *buffer, size_t size)
 Read multiple bytes from the EEprom.
template<typename T >
size_t read (size_t address, T &value)
 Deserialise object of type T from Eeprom memory.
size_t write (size_t address, char value)
 Write a char to EEprom.
size_t write (size_t address, const char *buffer, size_t size)
 Write multiple bytes to EEprom.
template<typename T >
size_t write (size_t address, const T &value)
 Serialise an object of type T.

Detailed Description

Based on the original Mbed I2CEeprom library by Robin Hourahane.

Class to provide simple access to I2C EEPROM chips like Microchip's 24LC or AMTELS AT24C series. Chips up to 64Kb in size are directly supported.

The library was tested on a Microchip 24LC128.

The I2CEeprom class handles multiple page writes so any amount of data can be written in a single call to write.

The code is modified from the original to better support RTOS. At start of a write(addr,buffer,size), a buffer of up to pageSize + 2 is allocated on the heap, and the data and address are copied to it. This allows the cuurent write chunk to proceed without unlocking, which prevents another device on the bus access and so aborting the write.

This allocation per write fits my usecase, where eeeprom variables are written in a special menu mode at start up, but it may be better to preallocate a buffer once at startup, if writes are occurring at arbitrary times during execution, to prevent surprises with out of memory issues when trying to write during normal execution.

The constructor takes the I2C bus by non-const reference argument. This enables a single I2C bus to be shared among many i2c devices. Mbed OS enforces a lock on the bus during a bus read/write so reads are atomic. Writes are split into separate atomic chunks that only write one eeprom page. After a chunk is sent, the thread is sent to sleep for writeCycleTime_ms specified in the constructor arg, and is then polled at 1 ms intervals to discover whether the write has completed.

Definition at line 58 of file I2CEeprom.h.


Constructor & Destructor Documentation

I2CEeprom ( I2C &  i2c,
int  address,
size_t  pageSize,
size_t  chipSize,
uint8_t  writeCycleTime_ms 
)

Constructor to create a new instance of the class.

Parameters:
i2cA reference to the i2c bus that the chip is connected to.
addressThe 8bit device I2C address
pageSizeThe device page size.
chipSizeThe device size for range check.
writeCycleTime_msThe device write cycle time in ms.

Definition at line 55 of file I2CEeprom.cpp.


Member Function Documentation

size_t read ( size_t  address,
char &  value 
)

Read a single byte from the EEprom.

Parameters:
addressEEprom read address.
valueMemory reference of char to read into.
Returns:
Number of bytes read .
size_t read ( size_t  address,
char *  buffer,
size_t  size 
)

Read multiple bytes from the EEprom.

Parameters:
addressEEprom start read address.
bufferbuffer to read into.
sizeNumber of bytes to read.
Returns:
Number of bytes read.
size_t read ( size_t  address,
T &  value 
)

Deserialise object of type T from Eeprom memory.

Parameters:
addressEEprom start address
valueMemory Reference of object to deserialise into .
Returns:
Number of bytes read.

Definition at line 91 of file I2CEeprom.h.

size_t write ( size_t  address,
char  value 
)

Write a char to EEprom.

Parameters:
addressEeprom write address.
valueChar value to write.
Returns:
Number of bytes written.
size_t write ( size_t  address,
const char *  buffer,
size_t  size 
)

Write multiple bytes to EEprom.

In this implementation, the write is split into chunks of up to pageSize and for each chunk a buffer of up to pageSize + 2 is temporarily allocated on the heap while the write is in progress.

Parameters:
addressEEprom start address.
bufferBuffer to write.
sizeNumber of bytes to write.
Returns:
Number of bytes written.
size_t write ( size_t  address,
const T &  value 
)

Serialise an object of type T.

Parameters:
addressEEprom start address.
valueObject to be serialised.
Returns:
Number of bytes written.

Definition at line 116 of file I2CEeprom.h.