Line data Source code
1 1 : /* 2 : * Copyright (c) 2019 Vestas Wind Systems A/S 3 : * 4 : * Heavily based on drivers/flash.h which is: 5 : * Copyright (c) 2017 Nordic Semiconductor ASA 6 : * Copyright (c) 2016 Intel Corporation 7 : * 8 : * SPDX-License-Identifier: Apache-2.0 9 : */ 10 : 11 : /** 12 : * @file 13 : * @brief Public API for EEPROM drivers 14 : */ 15 : 16 : #ifndef ZEPHYR_INCLUDE_DRIVERS_EEPROM_H_ 17 : #define ZEPHYR_INCLUDE_DRIVERS_EEPROM_H_ 18 : 19 : /** 20 : * @brief EEPROM Interface 21 : * @defgroup eeprom_interface EEPROM Interface 22 : * @since 2.1 23 : * @version 1.0.0 24 : * @ingroup io_interfaces 25 : * @{ 26 : */ 27 : 28 : #include <zephyr/types.h> 29 : #include <stddef.h> 30 : #include <sys/types.h> 31 : #include <zephyr/device.h> 32 : 33 : #ifdef __cplusplus 34 : extern "C" { 35 : #endif 36 : 37 : /** 38 : * @cond INTERNAL_HIDDEN 39 : * 40 : * For internal driver use only, skip these in public documentation. 41 : */ 42 : 43 : /** 44 : * @brief Callback API upon reading from the EEPROM. 45 : * See @a eeprom_read() for argument description 46 : */ 47 : typedef int (*eeprom_api_read)(const struct device *dev, off_t offset, 48 : void *data, 49 : size_t len); 50 : 51 : /** 52 : * @brief Callback API upon writing to the EEPROM. 53 : * See @a eeprom_write() for argument description 54 : */ 55 : typedef int (*eeprom_api_write)(const struct device *dev, off_t offset, 56 : const void *data, size_t len); 57 : 58 : /** 59 : * @brief Callback API upon getting the EEPROM size. 60 : * See @a eeprom_get_size() for argument description 61 : */ 62 : typedef size_t (*eeprom_api_size)(const struct device *dev); 63 : 64 : __subsystem struct eeprom_driver_api { 65 : eeprom_api_read read; 66 : eeprom_api_write write; 67 : eeprom_api_size size; 68 : }; 69 : 70 : /** @endcond */ 71 : 72 : /** 73 : * @brief Read data from EEPROM 74 : * 75 : * @param dev EEPROM device 76 : * @param offset Address offset to read from. 77 : * @param data Buffer to store read data. 78 : * @param len Number of bytes to read. 79 : * 80 : * @return 0 on success, negative errno code on failure. 81 : */ 82 1 : __syscall int eeprom_read(const struct device *dev, off_t offset, void *data, 83 : size_t len); 84 : 85 : static inline int z_impl_eeprom_read(const struct device *dev, off_t offset, 86 : void *data, size_t len) 87 : { 88 : const struct eeprom_driver_api *api = 89 : (const struct eeprom_driver_api *)dev->api; 90 : 91 : return api->read(dev, offset, data, len); 92 : } 93 : 94 : /** 95 : * @brief Write data to EEPROM 96 : * 97 : * @param dev EEPROM device 98 : * @param offset Address offset to write data to. 99 : * @param data Buffer with data to write. 100 : * @param len Number of bytes to write. 101 : * 102 : * @return 0 on success, negative errno code on failure. 103 : */ 104 1 : __syscall int eeprom_write(const struct device *dev, off_t offset, 105 : const void *data, 106 : size_t len); 107 : 108 : static inline int z_impl_eeprom_write(const struct device *dev, off_t offset, 109 : const void *data, size_t len) 110 : { 111 : const struct eeprom_driver_api *api = 112 : (const struct eeprom_driver_api *)dev->api; 113 : 114 : return api->write(dev, offset, data, len); 115 : } 116 : 117 : /** 118 : * @brief Get the size of the EEPROM in bytes 119 : * 120 : * @param dev EEPROM device. 121 : * 122 : * @return EEPROM size in bytes. 123 : */ 124 1 : __syscall size_t eeprom_get_size(const struct device *dev); 125 : 126 : static inline size_t z_impl_eeprom_get_size(const struct device *dev) 127 : { 128 : const struct eeprom_driver_api *api = 129 : (const struct eeprom_driver_api *)dev->api; 130 : 131 : return api->size(dev); 132 : } 133 : 134 : #ifdef __cplusplus 135 : } 136 : #endif 137 : 138 : /** 139 : * @} 140 : */ 141 : 142 : #include <zephyr/syscalls/eeprom.h> 143 : 144 : #endif /* ZEPHYR_INCLUDE_DRIVERS_EEPROM_H_ */