123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- /* NVS: non volatile storage in flash
- *
- * Copyright (c) 2018 Laczen
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #ifndef ZEPHYR_INCLUDE_FS_NVS_H_
- #define ZEPHYR_INCLUDE_FS_NVS_H_
- #include <sys/types.h>
- #include <kernel.h>
- #include <device.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @brief Non-volatile Storage
- * @defgroup nvs Non-volatile Storage
- * @ingroup file_system_storage
- * @{
- * @}
- */
- /**
- * @brief Non-volatile Storage Data Structures
- * @defgroup nvs_data_structures Non-volatile Storage Data Structures
- * @ingroup nvs
- * @{
- */
- /**
- * @brief Non-volatile Storage File system structure
- *
- * @param offset File system offset in flash
- * @param ate_wra Allocation table entry write address. Addresses are stored as uint32_t:
- * high 2 bytes correspond to the sector, low 2 bytes are the offset in the sector
- * @param data_wra Data write address
- * @param sector_size File system is split into sectors, each sector must be multiple of pagesize
- * @param sector_count Number of sectors in the file systems
- * @param ready Flag indicating if the filesystem is initialized
- * @param nvs_lock Mutex
- * @param flash_device Flash Device runtime structure
- * @param flash_parameters Flash memory parameters structure
- */
- struct nvs_fs {
- off_t offset;
- uint32_t ate_wra;
- uint32_t data_wra;
- uint16_t sector_size;
- uint16_t sector_count;
- bool ready;
- struct k_mutex nvs_lock;
- const struct device *flash_device;
- const struct flash_parameters *flash_parameters;
- };
- /**
- * @}
- */
- /**
- * @brief Non-volatile Storage APIs
- * @defgroup nvs_high_level_api Non-volatile Storage APIs
- * @ingroup nvs
- * @{
- */
- /**
- * @brief nvs_init
- *
- * Initializes a NVS file system in flash.
- *
- * @param fs Pointer to file system
- * @param dev_name Pointer to flash device name
- * @retval 0 Success
- * @retval -ERRNO errno code if error
- */
- int nvs_init(struct nvs_fs *fs, const char *dev_name);
- /**
- * @brief nvs_clear
- *
- * Clears the NVS file system from flash.
- * @param fs Pointer to file system
- * @retval 0 Success
- * @retval -ERRNO errno code if error
- */
- int nvs_clear(struct nvs_fs *fs);
- /**
- * @brief nvs_write
- *
- * Write an entry to the file system.
- *
- * @param fs Pointer to file system
- * @param id Id of the entry to be written
- * @param data Pointer to the data to be written
- * @param len Number of bytes to be written
- *
- * @return Number of bytes written. On success, it will be equal to the number of bytes requested
- * to be written. When a rewrite of the same data already stored is attempted, nothing is written
- * to flash, thus 0 is returned. On error, returns negative value of errno.h defined error codes.
- */
- ssize_t nvs_write(struct nvs_fs *fs, uint16_t id, const void *data, size_t len);
- /**
- * @brief nvs_delete
- *
- * Delete an entry from the file system
- *
- * @param fs Pointer to file system
- * @param id Id of the entry to be deleted
- * @retval 0 Success
- * @retval -ERRNO errno code if error
- */
- int nvs_delete(struct nvs_fs *fs, uint16_t id);
- /**
- * @brief nvs_read
- *
- * Read an entry from the file system.
- *
- * @param fs Pointer to file system
- * @param id Id of the entry to be read
- * @param data Pointer to data buffer
- * @param len Number of bytes to be read
- *
- * @return Number of bytes read. On success, it will be equal to the number of bytes requested
- * to be read. When the return value is larger than the number of bytes requested to read this
- * indicates not all bytes were read, and more data is available. On error, returns negative
- * value of errno.h defined error codes.
- */
- ssize_t nvs_read(struct nvs_fs *fs, uint16_t id, void *data, size_t len);
- /**
- * @brief nvs_read_hist
- *
- * Read a history entry from the file system.
- *
- * @param fs Pointer to file system
- * @param id Id of the entry to be read
- * @param data Pointer to data buffer
- * @param len Number of bytes to be read
- * @param cnt History counter: 0: latest entry, 1: one before latest ...
- *
- * @return Number of bytes read. On success, it will be equal to the number of bytes requested
- * to be read. When the return value is larger than the number of bytes requested to read this
- * indicates not all bytes were read, and more data is available. On error, returns negative
- * value of errno.h defined error codes.
- */
- ssize_t nvs_read_hist(struct nvs_fs *fs, uint16_t id, void *data, size_t len, uint16_t cnt);
- /**
- * @brief nvs_calc_free_space
- *
- * Calculate the available free space in the file system.
- *
- * @param fs Pointer to file system
- *
- * @return Number of bytes free. On success, it will be equal to the number of bytes that can
- * still be written to the file system. Calculating the free space is a time consuming operation,
- * especially on spi flash. On error, returns negative value of errno.h defined error codes.
- */
- ssize_t nvs_calc_free_space(struct nvs_fs *fs);
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /* ZEPHYR_INCLUDE_FS_NVS_H_ */
|