1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

Merge pull request #20588 from crasbe/master

drivers/at24cxxx: Add M24C01 device and enhance documentation
This commit is contained in:
Marian Buschsieweke 2024-04-17 08:40:04 +00:00 committed by GitHub
commit 8cff167a93
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 85 additions and 2 deletions

View File

@ -104,6 +104,10 @@ ifneq (,$(filter ltc4150_%,$(USEMODULE)))
USEMODULE += ltc4150 USEMODULE += ltc4150
endif endif
ifneq (,$(filter m24c%,$(USEMODULE)))
USEMODULE += at24cxxx
endif
ifneq (,$(filter mhz19_%,$(USEMODULE))) ifneq (,$(filter mhz19_%,$(USEMODULE)))
USEMODULE += mhz19 USEMODULE += mhz19
endif endif

View File

@ -1,5 +1,7 @@
PSEUDOMODULES += at24c% PSEUDOMODULES += at24c%
PSEUDOMODULES += mtd_at24cxxx PSEUDOMODULES += mtd_at24cxxx
PSEUDOMODULES += m24c%
# handle at24cxxx being a distinct module # handle at24cxxx being a distinct module
NO_PSEUDOMODULES += at24cxxx NO_PSEUDOMODULES += at24cxxx

View File

@ -11,7 +11,12 @@
* @{ * @{
* *
* @file * @file
* @brief Constants for AT24CXXX EEPROM devices. * @brief Constants for various I2C EEPROM devices.
*
* All the devices listed below are accessible as pseudomodules.
*
* @note Even though the library is called "AT24CXXX", the support for
* I2C EEPROMs is not limited to Atmel/Microchip devices.
* *
* @author Fabian Hüßler <fabian.huessler@ovgu.de> * @author Fabian Hüßler <fabian.huessler@ovgu.de>
*/ */
@ -367,6 +372,29 @@ extern "C" {
/ AT24CXXX_POLL_DELAY_US)) / AT24CXXX_POLL_DELAY_US))
/** @} */ /** @} */
/**
* @name M24C01 constants
* @{
*/
/**
* @brief 128 byte memory
*/
#define M24C01_EEPROM_SIZE (128U)
/**
* @brief 16 pages of 16 bytes each
*/
#define M24C01_PAGE_SIZE (16U)
/**
* @brief Delay to complete write operation
*/
#define M24C01_PAGE_WRITE_DELAY_US (5000U)
/**
* @brief Number of poll attempts
*/
#define M24C01_MAX_POLLS (1 + (M24C01_PAGE_WRITE_DELAY_US \
/ AT24CXXX_POLL_DELAY_US))
/** @} */
/** /**
* @name Set constants depending on module * @name Set constants depending on module
* @{ * @{
@ -427,6 +455,10 @@ extern "C" {
#define AT24CXXX_EEPROM_SIZE (AT24MAC_EEPROM_SIZE) #define AT24CXXX_EEPROM_SIZE (AT24MAC_EEPROM_SIZE)
#define AT24CXXX_PAGE_SIZE (AT24MAC_PAGE_SIZE) #define AT24CXXX_PAGE_SIZE (AT24MAC_PAGE_SIZE)
#define AT24CXXX_MAX_POLLS (AT24MAC_MAX_POLLS) #define AT24CXXX_MAX_POLLS (AT24MAC_MAX_POLLS)
#elif IS_USED(MODULE_M24C01)
#define AT24CXXX_EEPROM_SIZE (M24C01_EEPROM_SIZE)
#define AT24CXXX_PAGE_SIZE (M24C01_PAGE_SIZE)
#define AT24CXXX_MAX_POLLS (M24C01_MAX_POLLS)
#else /* minimal */ #else /* minimal */
#define AT24CXXX_EEPROM_SIZE (128U) /**< EEPROM size */ #define AT24CXXX_EEPROM_SIZE (128U) /**< EEPROM size */
#define AT24CXXX_PAGE_SIZE (4U) /**< page size */ #define AT24CXXX_PAGE_SIZE (4U) /**< page size */

View File

@ -11,7 +11,7 @@
* @{ * @{
* *
* @file * @file
* @brief Default configuration for AT24CXXX * @brief Default configuration for the AT24CXXX driver
* *
* @author Fabian Hüßler <fabian.huessler@ovgu.de> * @author Fabian Hüßler <fabian.huessler@ovgu.de>
*/ */

View File

@ -11,6 +11,51 @@
* @ingroup drivers_misc * @ingroup drivers_misc
* @brief Device driver interface for the AT24CXXX EEPROM units * @brief Device driver interface for the AT24CXXX EEPROM units
* *
* @section overview Overview
* Various manufacturers such as Atmel/Microchip or ST offer small I2C EEPROMs which usually
* come in 8-pin packages and are used for persistent data storage of settings, counters, etc.
* This driver adds support for these devices with direct read and write functions.
*
* The high level wrapper for RIOTs MTD interface to utilize the I2C EEPROMs as MTD storage
* is described in drivers_mtd_at24cxxx.
*
* A list of supported devices can be found in the at24cxxx_defines.h file.
*
* @section usage Usage
*
* The preconfigured devices in the at24cxxx_defines.h file devices are easily
* accessible as pseudomodules and can be added to the Makefile of your project:
*
* USEMODULE += at24c02
*
* When using one of the pseudomodules, the configuration of the device is already
* predefined in the AT24CXXX_PARAMS macro and can be used for the
* initialization:
*
* at24cxxx_t eeprom_dev;
* at24cxxx_params_t eeprom_params = AT24CXXX_PARAMS;
*
* at24cxxx_init(&eeprom_dev, &eeprom_params);
*
* \n
* For other devices that are not yet part of the library, the generic module
* has to be added:
*
* USEMODULE += at24cxxx
*
* The predefined macro can not be used in this case, so the parameters of the
* device have to be added to the at24cxxx_params_t structure manually with
* the values from the corresponding datasheet:
*
* at24cxxx_t eeprom_dev;
* at24cxxx_params_t eeprom_params = {
* .i2c = I2C_DEV(0), \
* ...
* };
*
* at24cxxx_init(&eeprom_dev, &eeprom_params);
*
*
* @{ * @{
* *
* @file * @file