/* * Copyright (C) 2020 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. * */ /** * @ingroup drivers_at24cxxx * @{ * * @file * @brief MTD EEPROM driver implementation for at24cxxx EEPROM * * @author Fabian Hüßler * * @} */ #include #include #include "mtd_at24cxxx.h" #define DEV(mtd_ptr) (((mtd_at24cxxx_t *)(mtd_ptr))->at24cxxx_eeprom) #define PARAMS(mtd_ptr) (((mtd_at24cxxx_t *)(mtd_ptr))->params) static int _mtd_at24cxxx_init(mtd_dev_t *mtd) { assert(mtd); assert(mtd->driver == &mtd_at24cxxx_driver); assert(DEV(mtd)); assert(PARAMS(mtd)); int init = at24cxxx_init(DEV(mtd), PARAMS(mtd)); if (init != AT24CXXX_OK) { return init; } mtd->page_size = DEV(mtd)->params.page_size; mtd->pages_per_sector = 1; mtd->sector_count = DEV(mtd)->params.eeprom_size / DEV(mtd)->params.page_size; mtd->write_size = 1; return 0; } static int _mtd_at24cxxx_read(mtd_dev_t *mtd, void *dest, uint32_t addr, uint32_t size) { return at24cxxx_read(DEV(mtd), addr, dest, size) == AT24CXXX_OK ? 0 : -EIO; } static int _mtd_at24cxxx_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uint32_t size) { return at24cxxx_write(DEV(mtd), addr, src, size) == AT24CXXX_OK ? 0 : -EIO; } static int mtd_at24cxxx_write_page(mtd_dev_t *mtd, const void *src, uint32_t page, uint32_t offset, uint32_t size) { return at24cxxx_write_page(DEV(mtd), page, offset, src, size); } static int _mtd_at24cxxx_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t size) { return at24cxxx_clear(DEV(mtd), addr, size) == AT24CXXX_OK ? 0 : -EIO; } static int _mtd_at24cxxx_power(mtd_dev_t *mtd, enum mtd_power_state power) { (void)mtd; (void)power; return -ENOTSUP; } const mtd_desc_t mtd_at24cxxx_driver = { .init = _mtd_at24cxxx_init, .read = _mtd_at24cxxx_read, .write = _mtd_at24cxxx_write, .write_page = mtd_at24cxxx_write_page, .erase = _mtd_at24cxxx_erase, .power = _mtd_at24cxxx_power, .flags = MTD_DRIVER_FLAG_DIRECT_WRITE, };