1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/drivers/include/at24cxxx.h
2023-02-15 11:56:21 +01:00

217 lines
6.3 KiB
C

/*
* Copyright (C) 2019 Otto-von-Guericke-Universität Magdeburg
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup drivers_at24cxxx AT24CXXX EEPROM unit
* @ingroup drivers_misc
* @brief Device driver interface for the AT24CXXX EEPROM units
*
* @{
*
* @file
* @brief Device driver interface for AT24CXXX EEPROM units.
*
* @author Fabian Hüßler <fabian.huessler@ovgu.de>
*
*/
#ifndef AT24CXXX_H
#define AT24CXXX_H
#include <stdint.h>
#include "periph/gpio.h"
#include "periph/i2c.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Return values
*/
enum {
AT24CXXX_OK,
AT24CXXX_I2C_ERROR
};
/**
* @brief Struct that holds initialization parameters
*/
typedef struct at24cxxx_params {
i2c_t i2c; /**< I2C bus number */
gpio_t pin_wp; /**< write protect pin */
uint32_t eeprom_size; /**< EEPROM memory capacity */
uint8_t dev_addr; /**< I2C device address */
uint8_t page_size; /**< page size */
uint8_t max_polls; /**< number of ACK poll attempts */
} at24cxxx_params_t;
/**
* @brief Struct that represents an AT24CXXX device
*/
typedef struct {
at24cxxx_params_t params; /**< parameters */
} at24cxxx_t;
/**
* @brief Initialize an AT24CXXX device handle with AT24CXXX parameters
*
* @param[in, out] dev AT24CXXX device handle
* @param[in] params AT24CXXX parameters
*
* @return AT24CXXX_OK on success
* @return -AT24CXXX_I2C_ERROR if i2c could not be acquired
* @return -EINVAL if input parameters are NULL
*/
int at24cxxx_init(at24cxxx_t *dev, const at24cxxx_params_t *params);
/**
* @brief Read a byte at a given position @p pos
*
* @param[in] dev AT24CXXX device handle
* @param[in] pos Position in EEPROM memory
* @param[out] dest Read byte
*
* @return AT24CXXX_OK on success
* @return -ERANGE if @p pos is out of bounds
* @return @see i2c_read_regs
*/
int at24cxxx_read_byte(const at24cxxx_t *dev, uint32_t pos, void *dest);
/**
* @brief Sequentially read @p len bytes from a given position @p pos
*
* @param[in] dev AT24CXXX device handle
* @param[in] pos Position in EEPROM memory
* @param[out] data Read buffer
* @param[in] len Requested length to be read
*
* @return AT24CXXX_OK on success
* @return -ERANGE if @p pos + @p len is out of bounds
* @return @see i2c_read_regs
*/
int at24cxxx_read(const at24cxxx_t *dev, uint32_t pos, void *data, size_t len);
/**
* @brief Write a byte at a given position @p pos
*
* @param[in] dev AT24CXXX device handle
* @param[in] pos Position in EEPROM memory
* @param[in] data Value to be written
*
* @return AT24CXXX_OK on success
* @return -ERANGE if @p pos is out of bounds
* @return @see i2c_write_regs
*/
int at24cxxx_write_byte(const at24cxxx_t *dev, uint32_t pos, uint8_t data);
/**
* @brief Sequentially write @p len bytes from a given position @p pos
*
* Writing is performed in chunks of size AT24CXXX_PAGE_SIZE.
*
* @param[in] dev AT24CXXX device handle
* @param[in] pos Position in EEPROM memory
* @param[in] data Write buffer
* @param[in] len Requested length to be written
*
* @return AT24CXXX_OK on success
* @return -ERANGE if @p pos + @p len is out of bounds
* @return @see i2c_write_regs
*/
int at24cxxx_write(const at24cxxx_t *dev, uint32_t pos, const void *data,
size_t len);
/**
* @brief Sequentially write @p len bytes to a given @p page.
* The function will write up to the page boundary and then return
* the number of bytes written up to that.
*
* @param[in] dev AT24CXXX device handle
* @param[in] page page of EEPROM memory
* @param[in] offset offset from the start of the page, must be < page size
* @param[in] data write buffer
* @param[in] len requested length to be written
*
* @return number of bytes written on success
* @return error on failure
*/
int at24cxxx_write_page(const at24cxxx_t *dev, uint32_t page, uint32_t offset,
const void *data, size_t len);
/**
* @brief Set @p len bytes from a given position @p pos to the
* value @p val
*
* Writing is performed in chunks of size AT24CXXX_SET_BUFFER_SIZE.
*
* @param[in] dev AT24CXXX device handle
* @param[in] pos Position in EEPROM memory
* @param[in] val Value to be set
* @param[in] len Requested length to be written
*
* @return AT24CXXX_OK on success
* @return -ERANGE if @p pos + @p len is out of bounds
* @return @see i2c_write_byte
*/
int at24cxxx_set(const at24cxxx_t *dev, uint32_t pos, uint8_t val,
size_t len);
/**
* @brief Set @p len bytes from position @p pos to
* AT24CXXX_CLEAR_BYTE
*
* This is a wrapper around @see at24cxxx_set.
*
* @param[in] dev AT24CXXX device handle
* @param[in] pos Position in EEPROM memory
* @param[in] len Requested length to be written
*
* @return @see at24cxxx_set
*/
int at24cxxx_clear(const at24cxxx_t *dev, uint32_t pos, size_t len);
/**
* @brief Set the entire EEPROM memory to AT24CXXX_CLEAR_BYTE
*
* This is a wrapper around @see at24cxxx_clear.
*
* @param[in] dev AT24CXXX device handle
*
* @return @see at24cxxx_set
*/
int at24cxxx_erase(const at24cxxx_t *dev);
/**
* @brief Enable write protection
*
* @param[in] dev AT24CXXX device handle
*
* @return AT24CXXX_OK on success
* @return -ENOTSUP if pin_wp was initialized with GPIO_UNDEF
*/
int at24cxxx_enable_write_protect(const at24cxxx_t *dev);
/**
* @brief Disable write protection
*
* @param[in] dev AT24CXXX device handle
*
* @return AT24CXXX_OK on success
* @return -ENOTSUP if pin_wp was initialized with GPIO_UNDEF
*/
int at24cxxx_disable_write_protect(const at24cxxx_t *dev);
#ifdef __cplusplus
}
#endif
#endif /* AT24CXXX_H */
/** @} */