2021-12-01 12:16:49 +08:00
/*
2023-06-02 21:36:01 +02:00
* SPDX - FileCopyrightText : 2015 - 2023 Espressif Systems ( Shanghai ) CO LTD
2021-12-01 12:16:49 +08:00
*
* SPDX - License - Identifier : Apache - 2.0
*/
2016-08-17 23:08:22 +08:00
# ifndef ESP_NVS_H
# define ESP_NVS_H
# include <stdint.h>
# include <stddef.h>
# include <stdbool.h>
2019-04-17 16:31:07 +10:00
# include "esp_attr.h"
2016-09-20 18:00:49 +08:00
# include "esp_err.h"
2016-08-17 23:08:22 +08:00
# ifdef __cplusplus
extern " C " {
# endif
/**
* Opaque pointer type representing non - volatile storage handle
*/
2019-04-01 15:13:55 +01:00
typedef uint32_t nvs_handle_t ;
/*
* Pre - IDF V4 .0 uses nvs_handle , so leaving the original typedef here for compatibility .
*/
2019-04-17 16:31:07 +10:00
typedef nvs_handle_t nvs_handle IDF_DEPRECATED ( " Replace with nvs_handle_t " ) ;
2016-08-17 23:08:22 +08:00
2018-07-02 16:40:43 +05:30
# define ESP_ERR_NVS_BASE 0x1100 /*!< Starting number of error codes */
# define ESP_ERR_NVS_NOT_INITIALIZED (ESP_ERR_NVS_BASE + 0x01) /*!< The storage driver is not initialized */
2022-05-11 18:49:55 +08:00
# define ESP_ERR_NVS_NOT_FOUND (ESP_ERR_NVS_BASE + 0x02) /*!< A requested entry couldn't be found or namespace doesn’ t exist yet and mode is NVS_READONLY */
2018-07-02 16:40:43 +05:30
# define ESP_ERR_NVS_TYPE_MISMATCH (ESP_ERR_NVS_BASE + 0x03) /*!< The type of set or get operation doesn't match the type of value stored in NVS */
# define ESP_ERR_NVS_READ_ONLY (ESP_ERR_NVS_BASE + 0x04) /*!< Storage handle was opened as read only */
# define ESP_ERR_NVS_NOT_ENOUGH_SPACE (ESP_ERR_NVS_BASE + 0x05) /*!< There is not enough space in the underlying storage to save the value */
# define ESP_ERR_NVS_INVALID_NAME (ESP_ERR_NVS_BASE + 0x06) /*!< Namespace name doesn’ t satisfy constraints */
# define ESP_ERR_NVS_INVALID_HANDLE (ESP_ERR_NVS_BASE + 0x07) /*!< Handle has been closed or is NULL */
# define ESP_ERR_NVS_REMOVE_FAILED (ESP_ERR_NVS_BASE + 0x08) /*!< The value wasn’ t updated because flash write operation has failed. The value was written however, and update will be finished after re-initialization of nvs, provided that flash operation doesn’ t fail again. */
# define ESP_ERR_NVS_KEY_TOO_LONG (ESP_ERR_NVS_BASE + 0x09) /*!< Key name is too long */
# define ESP_ERR_NVS_PAGE_FULL (ESP_ERR_NVS_BASE + 0x0a) /*!< Internal error; never returned by nvs API functions */
# define ESP_ERR_NVS_INVALID_STATE (ESP_ERR_NVS_BASE + 0x0b) /*!< NVS is in an inconsistent state due to a previous error. Call nvs_flash_init and nvs_open again, then retry. */
# define ESP_ERR_NVS_INVALID_LENGTH (ESP_ERR_NVS_BASE + 0x0c) /*!< String or blob length is not sufficient to store data */
# define ESP_ERR_NVS_NO_FREE_PAGES (ESP_ERR_NVS_BASE + 0x0d) /*!< NVS partition doesn't contain any empty pages. This may happen if NVS partition was truncated. Erase the whole partition and call nvs_flash_init again. */
2022-04-08 15:06:30 +02:00
# define ESP_ERR_NVS_VALUE_TOO_LONG (ESP_ERR_NVS_BASE + 0x0e) /*!< Value doesn't fit into the entry or string or blob length is longer than supported by the implementation */
2018-07-02 16:40:43 +05:30
# define ESP_ERR_NVS_PART_NOT_FOUND (ESP_ERR_NVS_BASE + 0x0f) /*!< Partition with specified name is not found in the partition table */
# define ESP_ERR_NVS_NEW_VERSION_FOUND (ESP_ERR_NVS_BASE + 0x10) /*!< NVS partition contains data in new format and cannot be recognized by this version of code */
# define ESP_ERR_NVS_XTS_ENCR_FAILED (ESP_ERR_NVS_BASE + 0x11) /*!< XTS encryption failed while writing NVS entry */
# define ESP_ERR_NVS_XTS_DECR_FAILED (ESP_ERR_NVS_BASE + 0x12) /*!< XTS decryption failed while reading NVS entry */
# define ESP_ERR_NVS_XTS_CFG_FAILED (ESP_ERR_NVS_BASE + 0x13) /*!< XTS configuration setting failed */
# define ESP_ERR_NVS_XTS_CFG_NOT_FOUND (ESP_ERR_NVS_BASE + 0x14) /*!< XTS configuration not found */
# define ESP_ERR_NVS_ENCR_NOT_SUPPORTED (ESP_ERR_NVS_BASE + 0x15) /*!< NVS encryption is not supported in this version */
# define ESP_ERR_NVS_KEYS_NOT_INITIALIZED (ESP_ERR_NVS_BASE + 0x16) /*!< NVS key partition is uninitialized */
# define ESP_ERR_NVS_CORRUPT_KEY_PART (ESP_ERR_NVS_BASE + 0x17) /*!< NVS key partition is corrupt */
2020-04-27 08:51:31 +08:00
# define ESP_ERR_NVS_WRONG_ENCRYPTION (ESP_ERR_NVS_BASE + 0x19) /*!< NVS partition is marked as encrypted with generic flash encryption. This is forbidden since the NVS encryption works differently. */
2018-07-02 16:40:43 +05:30
2019-04-15 14:06:57 -05:00
# define ESP_ERR_NVS_CONTENT_DIFFERS (ESP_ERR_NVS_BASE + 0x18) /*!< Internal error; never returned by nvs API functions. NVS key is different in comparison */
2016-08-17 23:08:22 +08:00
2019-12-06 16:16:07 +08:00
# define NVS_DEFAULT_PART_NAME "nvs" /*!< Default partition name of the NVS partition in the partition table */
# define NVS_PART_NAME_MAX_SIZE 16 /*!< maximum length of partition name (excluding null terminator) */
2022-05-11 18:49:55 +08:00
# define NVS_KEY_NAME_MAX_SIZE 16 /*!< Maximum length of NVS key name (including null terminator) */
2022-09-26 18:02:54 +02:00
# define NVS_NS_NAME_MAX_SIZE NVS_KEY_NAME_MAX_SIZE /*!< Maximum length of NVS namespace name (including null terminator) */
2019-04-01 15:13:55 +01:00
2016-10-27 21:20:30 +02:00
/**
* @ brief Mode of opening the non - volatile storage
*/
2016-08-17 23:08:22 +08:00
typedef enum {
2016-10-27 21:20:30 +02:00
NVS_READONLY , /*!< Read only */
NVS_READWRITE /*!< Read and write */
2019-04-01 15:13:55 +01:00
} nvs_open_mode_t ;
/*
* Pre - IDF V4 .0 uses nvs_open_mode , so leaving the original typedef here for compatibility .
*/
2019-04-17 16:31:07 +10:00
typedef nvs_open_mode_t nvs_open_mode IDF_DEPRECATED ( " Replace with nvs_open_mode_t " ) ;
2016-08-17 23:08:22 +08:00
2018-11-05 09:03:04 +01:00
/**
* @ brief Types of variables
*
*/
2019-01-11 09:51:50 +08:00
typedef enum {
2018-11-05 09:03:04 +01:00
NVS_TYPE_U8 = 0x01 , /*!< Type uint8_t */
NVS_TYPE_I8 = 0x11 , /*!< Type int8_t */
NVS_TYPE_U16 = 0x02 , /*!< Type uint16_t */
NVS_TYPE_I16 = 0x12 , /*!< Type int16_t */
NVS_TYPE_U32 = 0x04 , /*!< Type uint32_t */
NVS_TYPE_I32 = 0x14 , /*!< Type int32_t */
NVS_TYPE_U64 = 0x08 , /*!< Type uint64_t */
NVS_TYPE_I64 = 0x18 , /*!< Type int64_t */
NVS_TYPE_STR = 0x21 , /*!< Type string */
NVS_TYPE_BLOB = 0x42 , /*!< Type blob */
NVS_TYPE_ANY = 0xff /*!< Must be last */
2019-01-11 09:51:50 +08:00
} nvs_type_t ;
2018-11-05 09:03:04 +01:00
/**
* @ brief information about entry obtained from nvs_entry_info function
*/
typedef struct {
2022-09-26 18:02:54 +02:00
char namespace_name [ NVS_NS_NAME_MAX_SIZE ] ; /*!< Namespace to which key-value belong */
char key [ NVS_KEY_NAME_MAX_SIZE ] ; /*!< Key of stored key-value pair */
nvs_type_t type ; /*!< Type of stored key-value pair */
2018-11-05 09:03:04 +01:00
} nvs_entry_info_t ;
/**
* Opaque pointer type representing iterator to nvs entries
*/
typedef struct nvs_opaque_iterator_t * nvs_iterator_t ;
2016-08-17 23:08:22 +08:00
/**
2017-08-21 15:26:16 +05:30
* @ brief Open non - volatile storage with a given namespace from the default NVS partition
2016-08-17 23:08:22 +08:00
*
2016-08-19 14:30:39 +08:00
* Multiple internal ESP - IDF and third party application modules can store
* their key - value pairs in the NVS module . In order to reduce possible
* conflicts on key names , each module can use its own namespace .
2017-08-21 15:26:16 +05:30
* The default NVS partition is the one that is labelled " nvs " in the partition
* table .
2016-08-17 23:08:22 +08:00
*
2022-05-11 18:49:55 +08:00
* @ param [ in ] namespace_name Namespace name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
* @ param [ in ] open_mode NVS_READWRITE or NVS_READONLY . If NVS_READONLY , will
* open a handle for reading only . All write requests will
* be rejected for this handle .
* @ param [ out ] out_handle If successful ( return code is zero ) , handle will be
* returned in this argument .
2017-08-21 15:26:16 +05:30
*
* @ return
* - ESP_OK if storage handle was opened successfully
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2017-08-21 15:26:16 +05:30
* - ESP_ERR_NVS_NOT_INITIALIZED if the storage driver is not initialized
* - ESP_ERR_NVS_PART_NOT_FOUND if the partition with label " nvs " is not found
* - ESP_ERR_NVS_NOT_FOUND id namespace doesn ' t exist yet and
* mode is NVS_READONLY
* - ESP_ERR_NVS_INVALID_NAME if namespace name doesn ' t satisfy constraints
2020-12-15 08:06:46 +05:30
* - ESP_ERR_NO_MEM in case memory could not be allocated for the internal structures
2022-08-23 17:10:16 +02:00
* - ESP_ERR_NVS_NOT_ENOUGH_SPACE if there is no space for a new entry or there are too many different
* namespaces ( maximum allowed different namespaces : 254 )
2023-07-17 11:59:28 +02:00
* - ESP_ERR_NOT_ALLOWED if the NVS partition is read - only and mode is NVS_READWRITE
2023-10-19 14:36:10 +02:00
* - ESP_ERR_INVALID_ARG if out_handle is equal to NULL
2017-08-21 15:26:16 +05:30
* - other error codes from the underlying storage driver
*/
2022-05-11 18:49:55 +08:00
esp_err_t nvs_open ( const char * namespace_name , nvs_open_mode_t open_mode , nvs_handle_t * out_handle ) ;
2017-08-21 15:26:16 +05:30
/**
* @ brief Open non - volatile storage with a given namespace from specified partition
*
* The behaviour is same as nvs_open ( ) API . However this API can operate on a specified NVS
* partition instead of default NVS partition . Note that the specified partition must be registered
* with NVS using nvs_flash_init_partition ( ) API .
*
2022-05-11 18:49:55 +08:00
* @ param [ in ] part_name Label ( name ) of the partition of interest for object read / write / erase
* @ param [ in ] namespace_name Namespace name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
* @ param [ in ] open_mode NVS_READWRITE or NVS_READONLY . If NVS_READONLY , will
* open a handle for reading only . All write requests will
* be rejected for this handle .
* @ param [ out ] out_handle If successful ( return code is zero ) , handle will be
* returned in this argument .
2016-08-17 23:08:22 +08:00
*
2016-10-30 19:37:45 +01:00
* @ return
* - ESP_OK if storage handle was opened successfully
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2016-08-17 23:08:22 +08:00
* - ESP_ERR_NVS_NOT_INITIALIZED if the storage driver is not initialized
2017-08-21 15:26:16 +05:30
* - ESP_ERR_NVS_PART_NOT_FOUND if the partition with specified name is not found
2016-08-17 23:08:22 +08:00
* - ESP_ERR_NVS_NOT_FOUND id namespace doesn ' t exist yet and
* mode is NVS_READONLY
* - ESP_ERR_NVS_INVALID_NAME if namespace name doesn ' t satisfy constraints
2020-12-15 08:06:46 +05:30
* - ESP_ERR_NO_MEM in case memory could not be allocated for the internal structures
2022-08-23 17:10:16 +02:00
* - ESP_ERR_NVS_NOT_ENOUGH_SPACE if there is no space for a new entry or there are too many different
* namespaces ( maximum allowed different namespaces : 254 )
2023-07-17 11:59:28 +02:00
* - ESP_ERR_NOT_ALLOWED if the NVS partition is read - only and mode is NVS_READWRITE
2023-10-19 14:36:10 +02:00
* - ESP_ERR_INVALID_ARG if out_handle is equal to NULL
2016-08-17 23:08:22 +08:00
* - other error codes from the underlying storage driver
*/
2022-05-11 18:49:55 +08:00
esp_err_t nvs_open_from_partition ( const char * part_name , const char * namespace_name , nvs_open_mode_t open_mode , nvs_handle_t * out_handle ) ;
2016-08-17 23:08:22 +08:00
2016-11-16 01:35:09 +08:00
/**@{*/
2016-08-17 23:08:22 +08:00
/**
2021-01-19 16:15:40 +08:00
* @ brief set int8_t value for given key
2016-08-17 23:08:22 +08:00
*
2021-01-19 16:15:40 +08:00
* Set value for the key , given its name . Note that the actual storage will not be updated
2023-06-02 21:36:01 +02:00
* until \ c nvs_commit is called . Regardless whether key - value pair is created or updated ,
* function always requires at least one nvs available entry . See \ c nvs_get_stats .
* After create type of operation , the number of available entries is decreased by one .
* After update type of operation , the number of available entries remains the same .
2016-08-17 23:08:22 +08:00
*
2016-09-26 12:41:04 +08:00
* @ param [ in ] handle Handle obtained from nvs_open function .
* Handles that were opened read only cannot be used .
2022-05-11 18:49:55 +08:00
* @ param [ in ] key Key name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
2016-08-17 23:08:22 +08:00
* @ param [ in ] value The value to set .
*
2016-10-30 19:37:45 +01:00
* @ return
* - ESP_OK if value was set successfully
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2016-08-17 23:08:22 +08:00
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - ESP_ERR_NVS_READ_ONLY if storage handle was opened as read only
* - ESP_ERR_NVS_INVALID_NAME if key name doesn ' t satisfy constraints
* - ESP_ERR_NVS_NOT_ENOUGH_SPACE if there is not enough space in the
* underlying storage to save the value
2016-08-22 12:11:32 +08:00
* - ESP_ERR_NVS_REMOVE_FAILED if the value wasn ' t updated because flash
* write operation has failed . The value was written however , and
* update will be finished after re - initialization of nvs , provided that
* flash operation doesn ' t fail again .
2016-08-17 23:08:22 +08:00
*/
2021-01-19 16:15:40 +08:00
esp_err_t nvs_set_i8 ( nvs_handle_t handle , const char * key , int8_t value ) ;
/**
* @ brief set uint8_t value for given key
*
* This function is the same as \ c nvs_set_i8 except for the data type .
*/
esp_err_t nvs_set_u8 ( nvs_handle_t handle , const char * key , uint8_t value ) ;
/**
* @ brief set int16_t value for given key
*
* This function is the same as \ c nvs_set_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_i16 ( nvs_handle_t handle , const char * key , int16_t value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief set uint16_t value for given key
*
* This function is the same as \ c nvs_set_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_u16 ( nvs_handle_t handle , const char * key , uint16_t value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief set int32_t value for given key
*
* This function is the same as \ c nvs_set_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_i32 ( nvs_handle_t handle , const char * key , int32_t value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief set uint32_t value for given key
*
* This function is the same as \ c nvs_set_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_u32 ( nvs_handle_t handle , const char * key , uint32_t value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief set int64_t value for given key
*
* This function is the same as \ c nvs_set_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_i64 ( nvs_handle_t handle , const char * key , int64_t value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief set uint64_t value for given key
*
* This function is the same as \ c nvs_set_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_u64 ( nvs_handle_t handle , const char * key , uint64_t value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief set string for given key
*
2023-06-02 21:36:01 +02:00
* Sets string value for the key . Function requires whole space for new data to be available
* as contiguous entries in same nvs page . Operation consumes 1 overhead entry and 1 entry per
* each 32 characters of new string including zero character to be set . In case of value update
* for existing key , entries occupied by the previous value and overhead entry are returned to
* the pool of available entries .
* Note that storage of long string values can fail due to fragmentation of nvs pages even if
* \ c available_entries returned by \ c nvs_get_stats suggests enough overall space available .
* Note that the underlying storage will not be updated until \ c nvs_commit is called .
*
2021-01-19 16:15:40 +08:00
*
* @ param [ in ] handle Handle obtained from nvs_open function .
* Handles that were opened read only cannot be used .
2022-05-11 18:49:55 +08:00
* @ param [ in ] key Key name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
2021-01-19 16:15:40 +08:00
* @ param [ in ] value The value to set .
* For strings , the maximum length ( including null character ) is
* 4000 bytes , if there is one complete page free for writing .
* This decreases , however , if the free space is fragmented .
*
* @ return
* - ESP_OK if value was set successfully
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - ESP_ERR_NVS_READ_ONLY if storage handle was opened as read only
* - ESP_ERR_NVS_INVALID_NAME if key name doesn ' t satisfy constraints
* - ESP_ERR_NVS_NOT_ENOUGH_SPACE if there is not enough space in the
* underlying storage to save the value
* - ESP_ERR_NVS_REMOVE_FAILED if the value wasn ' t updated because flash
* write operation has failed . The value was written however , and
* update will be finished after re - initialization of nvs , provided that
* flash operation doesn ' t fail again .
* - ESP_ERR_NVS_VALUE_TOO_LONG if the string value is too long
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_str ( nvs_handle_t handle , const char * key , const char * value ) ;
2019-06-06 10:57:29 +08:00
/**@}*/
2016-11-16 01:35:09 +08:00
/**
* @ brief set variable length binary value for given key
*
2023-06-02 21:36:01 +02:00
* Sets variable length binary value for the key . Function uses 2 overhead and 1 entry
* per each 32 bytes of new data from the pool of available entries . See \ c nvs_get_stats .
* In case of value update for existing key , space occupied by the existing value and 2 overhead entries
* are returned to the pool of available entries .
* Note that the underlying storage will not be updated until \ c nvs_commit is called .
2016-11-16 01:35:09 +08:00
*
* @ param [ in ] handle Handle obtained from nvs_open function .
* Handles that were opened read only cannot be used .
2022-05-11 18:49:55 +08:00
* @ param [ in ] key Key name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
2016-11-16 01:35:09 +08:00
* @ param [ in ] value The value to set .
2017-05-31 12:59:24 +08:00
* @ param [ in ] length length of binary value to set , in bytes ; Maximum length is
2018-09-04 18:01:17 +05:30
* 508000 bytes or ( 97.6 % of the partition size - 4000 ) bytes
* whichever is lower .
2016-11-16 01:35:09 +08:00
*
* @ return
* - ESP_OK if value was set successfully
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2016-11-16 01:35:09 +08:00
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - ESP_ERR_NVS_READ_ONLY if storage handle was opened as read only
* - ESP_ERR_NVS_INVALID_NAME if key name doesn ' t satisfy constraints
* - ESP_ERR_NVS_NOT_ENOUGH_SPACE if there is not enough space in the
* underlying storage to save the value
* - ESP_ERR_NVS_REMOVE_FAILED if the value wasn ' t updated because flash
* write operation has failed . The value was written however , and
* update will be finished after re - initialization of nvs , provided that
* flash operation doesn ' t fail again .
2017-05-31 12:59:24 +08:00
* - ESP_ERR_NVS_VALUE_TOO_LONG if the value is too long
2016-11-16 01:35:09 +08:00
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_set_blob ( nvs_handle_t handle , const char * key , const void * value , size_t length ) ;
2016-08-17 23:08:22 +08:00
2016-11-16 01:35:09 +08:00
/**@{*/
2016-08-17 23:08:22 +08:00
/**
2021-01-19 16:15:40 +08:00
* @ brief get int8_t value for given key
2016-08-17 23:08:22 +08:00
*
2021-01-19 16:15:40 +08:00
* These functions retrieve value for the key , given its name . If \ c key does not
2016-08-17 23:08:22 +08:00
* exist , or the requested variable type doesn ' t match the type which was used
* when setting a value , an error is returned .
*
* In case of any error , out_value is not modified .
*
2021-01-19 16:15:40 +08:00
* \ c out_value has to be a pointer to an already allocated variable of the given type .
2016-11-16 01:35:09 +08:00
*
* \ code { c }
* // Example of using nvs_get_i32:
* int32_t max_buffer_size = 4096 ; // default value
* esp_err_t err = nvs_get_i32 ( my_handle , " max_buffer_size " , & max_buffer_size ) ;
* assert ( err = = ESP_OK | | err = = ESP_ERR_NVS_NOT_FOUND ) ;
* // if ESP_ERR_NVS_NOT_FOUND was returned, max_buffer_size will still
* // have its default value.
*
* \ endcode
*
* @ param [ in ] handle Handle obtained from nvs_open function .
2022-05-11 18:49:55 +08:00
* @ param [ in ] key Key name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
2016-11-16 01:35:09 +08:00
* @ param out_value Pointer to the output value .
* May be NULL for nvs_get_str and nvs_get_blob , in this
* case required length will be returned in length argument .
*
* @ return
* - ESP_OK if the value was retrieved successfully
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2016-11-16 01:35:09 +08:00
* - ESP_ERR_NVS_NOT_FOUND if the requested key doesn ' t exist
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - ESP_ERR_NVS_INVALID_NAME if key name doesn ' t satisfy constraints
* - ESP_ERR_NVS_INVALID_LENGTH if length is not sufficient to store data
*/
2021-01-19 16:15:40 +08:00
esp_err_t nvs_get_i8 ( nvs_handle_t handle , const char * key , int8_t * out_value ) ;
/**
* @ brief get uint8_t value for given key
*
* This function is the same as \ c nvs_get_i8 except for the data type .
*/
esp_err_t nvs_get_u8 ( nvs_handle_t handle , const char * key , uint8_t * out_value ) ;
/**
* @ brief get int16_t value for given key
*
* This function is the same as \ c nvs_get_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_i16 ( nvs_handle_t handle , const char * key , int16_t * out_value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief get uint16_t value for given key
*
* This function is the same as \ c nvs_get_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_u16 ( nvs_handle_t handle , const char * key , uint16_t * out_value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief get int32_t value for given key
*
* This function is the same as \ c nvs_get_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_i32 ( nvs_handle_t handle , const char * key , int32_t * out_value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief get uint32_t value for given key
*
* This function is the same as \ c nvs_get_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_u32 ( nvs_handle_t handle , const char * key , uint32_t * out_value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief get int64_t value for given key
*
* This function is the same as \ c nvs_get_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_i64 ( nvs_handle_t handle , const char * key , int64_t * out_value ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief get uint64_t value for given key
*
* This function is the same as \ c nvs_get_i8 except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_u64 ( nvs_handle_t handle , const char * key , uint64_t * out_value ) ;
2019-06-06 10:57:29 +08:00
/**@}*/
2016-11-16 01:35:09 +08:00
2021-01-19 16:15:40 +08:00
/**@{*/
2016-11-16 01:35:09 +08:00
/**
2021-01-19 16:15:40 +08:00
* @ brief get string value for given key
2016-11-16 01:35:09 +08:00
*
2019-11-25 11:32:40 +08:00
* These functions retrieve the data of an entry , given its key . If key does not
2016-11-16 01:35:09 +08:00
* exist , or the requested variable type doesn ' t match the type which was used
* when setting a value , an error is returned .
*
* In case of any error , out_value is not modified .
*
* All functions expect out_value to be a pointer to an already allocated variable
* of the given type .
2018-11-05 09:03:04 +01:00
*
2016-11-16 01:35:09 +08:00
* nvs_get_str and nvs_get_blob functions support WinAPI - style length queries .
2016-08-17 23:08:22 +08:00
* To get the size necessary to store the value , call nvs_get_str or nvs_get_blob
* with zero out_value and non - zero pointer to length . Variable pointed to
* by length argument will be set to the required length . For nvs_get_str ,
* this length includes the zero terminator . When calling nvs_get_str and
* nvs_get_blob with non - zero out_value , length has to be non - zero and has to
* point to the length available in out_value .
* It is suggested that nvs_get / set_str is used for zero - terminated C strings , and
* nvs_get / set_blob used for arbitrary data structures .
*
2016-10-27 21:20:30 +02:00
* \ code { c }
* // Example (without error checking) of using nvs_get_str to get a string into dynamic array:
2016-08-17 23:08:22 +08:00
* size_t required_size ;
* nvs_get_str ( my_handle , " server_name " , NULL , & required_size ) ;
* char * server_name = malloc ( required_size ) ;
* nvs_get_str ( my_handle , " server_name " , server_name , & required_size ) ;
*
2016-10-27 21:20:30 +02:00
* // Example (without error checking) of using nvs_get_blob to get a binary data
2016-08-17 23:08:22 +08:00
* into a static array :
* uint8_t mac_addr [ 6 ] ;
* size_t size = sizeof ( mac_addr ) ;
* nvs_get_blob ( my_handle , " dst_mac_addr " , mac_addr , & size ) ;
2016-10-27 21:20:30 +02:00
* \ endcode
2016-08-17 23:08:22 +08:00
*
* @ param [ in ] handle Handle obtained from nvs_open function .
2022-05-11 18:49:55 +08:00
* @ param [ in ] key Key name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
2021-01-19 16:15:40 +08:00
* @ param [ out ] out_value Pointer to the output value .
2016-08-17 23:08:22 +08:00
* May be NULL for nvs_get_str and nvs_get_blob , in this
* case required length will be returned in length argument .
2016-11-16 01:35:09 +08:00
* @ param [ inout ] length A non - zero pointer to the variable holding the length of out_value .
2016-08-17 23:08:22 +08:00
* In case out_value a zero , will be set to the length
* required to hold the value . In case out_value is not
* zero , will be set to the actual length of the value
* written . For nvs_get_str this includes zero terminator .
*
2016-10-30 19:37:45 +01:00
* @ return
* - ESP_OK if the value was retrieved successfully
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2016-08-17 23:08:22 +08:00
* - ESP_ERR_NVS_NOT_FOUND if the requested key doesn ' t exist
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - ESP_ERR_NVS_INVALID_NAME if key name doesn ' t satisfy constraints
2021-01-19 16:15:40 +08:00
* - ESP_ERR_NVS_INVALID_LENGTH if \ c length is not sufficient to store data
2016-08-17 23:08:22 +08:00
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_str ( nvs_handle_t handle , const char * key , char * out_value , size_t * length ) ;
2021-01-19 16:15:40 +08:00
/**
* @ brief get blob value for given key
*
* This function behaves the same as \ c nvs_get_str , except for the data type .
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_blob ( nvs_handle_t handle , const char * key , void * out_value , size_t * length ) ;
2016-11-16 01:35:09 +08:00
/**@}*/
2016-08-17 23:08:22 +08:00
2016-09-23 00:36:53 +08:00
/**
* @ brief Erase key - value pair with given key name .
*
* Note that actual storage may not be updated until nvs_commit function is called .
*
2016-09-26 12:41:04 +08:00
* @ param [ in ] handle Storage handle obtained with nvs_open .
* Handles that were opened read only cannot be used .
2016-09-23 00:36:53 +08:00
*
2022-05-11 18:49:55 +08:00
* @ param [ in ] key Key name . Maximum length is ( NVS_KEY_NAME_MAX_SIZE - 1 ) characters . Shouldn ' t be empty .
2016-09-23 00:36:53 +08:00
*
2016-10-30 19:37:45 +01:00
* @ return
* - ESP_OK if erase operation was successful
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2016-09-23 00:36:53 +08:00
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - ESP_ERR_NVS_READ_ONLY if handle was opened as read only
* - ESP_ERR_NVS_NOT_FOUND if the requested key doesn ' t exist
* - other error codes from the underlying storage driver
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_erase_key ( nvs_handle_t handle , const char * key ) ;
2016-09-23 00:36:53 +08:00
/**
* @ brief Erase all key - value pairs in a namespace
*
* Note that actual storage may not be updated until nvs_commit function is called .
*
2016-09-26 12:41:04 +08:00
* @ param [ in ] handle Storage handle obtained with nvs_open .
* Handles that were opened read only cannot be used .
2016-09-23 00:36:53 +08:00
*
2016-10-30 19:37:45 +01:00
* @ return
* - ESP_OK if erase operation was successful
2022-04-08 15:06:30 +02:00
* - ESP_FAIL if there is an internal error ; most likely due to corrupted
* NVS partition ( only if NVS assertion checks are disabled )
2016-09-23 00:36:53 +08:00
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - ESP_ERR_NVS_READ_ONLY if handle was opened as read only
* - other error codes from the underlying storage driver
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_erase_all ( nvs_handle_t handle ) ;
2016-09-23 00:36:53 +08:00
2016-08-17 23:08:22 +08:00
/**
* @ brief Write any pending changes to non - volatile storage
*
* After setting any values , nvs_commit ( ) must be called to ensure changes are written
* to non - volatile storage . Individual implementations may write to storage at other times ,
* but this is not guaranteed .
*
2016-09-26 12:41:04 +08:00
* @ param [ in ] handle Storage handle obtained with nvs_open .
* Handles that were opened read only cannot be used .
2016-08-17 23:08:22 +08:00
*
2016-10-30 19:37:45 +01:00
* @ return
* - ESP_OK if the changes have been written successfully
2016-08-17 23:08:22 +08:00
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL
* - other error codes from the underlying storage driver
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_commit ( nvs_handle_t handle ) ;
2016-08-17 23:08:22 +08:00
/**
* @ brief Close the storage handle and free any allocated resources
*
* This function should be called for each handle opened with nvs_open once
* the handle is not in use any more . Closing the handle may not automatically
* write the changes to nonvolatile storage . This has to be done explicitly using
* nvs_commit function .
* Once this function is called on a handle , the handle should no longer be used .
*
* @ param [ in ] handle Storage handle to close
*/
2019-04-01 15:13:55 +01:00
void nvs_close ( nvs_handle_t handle ) ;
2016-08-17 23:08:22 +08:00
2018-02-20 12:11:56 +05:00
/**
* @ note Info about storage space NVS .
*/
typedef struct {
2023-06-02 21:36:01 +02:00
size_t used_entries ; /**< Number of used entries. */
size_t free_entries ; /**< Number of free entries. It includes also reserved entries. */
size_t available_entries ; /**< Number of entries available for data storage. */
size_t total_entries ; /**< Number of all entries. */
size_t namespace_count ; /**< Number of namespaces. */
2018-02-20 12:11:56 +05:00
} nvs_stats_t ;
/**
2023-06-02 21:36:01 +02:00
* @ brief Fill structure nvs_stats_t . It provides info about memory used by NVS .
2018-02-20 12:11:56 +05:00
*
2023-06-02 21:36:01 +02:00
* This function calculates the number of used entries , free entries , available entries , total entries
* and number of namespaces in partition .
2018-02-20 12:11:56 +05:00
*
* \ code { c }
2023-06-02 21:36:01 +02:00
* // Example of nvs_get_stats() to get overview of actual statistics of data entries :
2018-02-20 12:11:56 +05:00
* nvs_stats_t nvs_stats ;
* nvs_get_stats ( NULL , & nvs_stats ) ;
2023-06-02 21:36:01 +02:00
* printf ( " Count: UsedEntries = (%lu), FreeEntries = (%lu), AvailableEntries = (%lu), AllEntries = (%lu) \n " ,
nvs_stats . used_entries , nvs_stats . free_entries , nvs_stats . available_entries , nvs_stats . total_entries ) ;
2018-02-20 12:11:56 +05:00
* \ endcode
*
* @ param [ in ] part_name Partition name NVS in the partition table .
* If pass a NULL than will use NVS_DEFAULT_PART_NAME ( " nvs " ) .
*
* @ param [ out ] nvs_stats Returns filled structure nvs_states_t .
* It provides info about used memory the partition .
*
*
* @ return
* - ESP_OK if the changes have been written successfully .
* Return param nvs_stats will be filled .
* - ESP_ERR_NVS_PART_NOT_FOUND if the partition with label " name " is not found .
* Return param nvs_stats will be filled 0.
* - ESP_ERR_NVS_NOT_INITIALIZED if the storage driver is not initialized .
* Return param nvs_stats will be filled 0.
2023-10-19 14:36:10 +02:00
* - ESP_ERR_INVALID_ARG if nvs_stats is equal to NULL .
2018-02-20 12:11:56 +05:00
* - ESP_ERR_INVALID_STATE if there is page with the status of INVALID .
* Return param nvs_stats will be filled not with correct values because
* not all pages will be counted . Counting will be interrupted at the first INVALID page .
*/
2018-11-05 09:03:04 +01:00
esp_err_t nvs_get_stats ( const char * part_name , nvs_stats_t * nvs_stats ) ;
2018-02-20 12:11:56 +05:00
/**
* @ brief Calculate all entries in a namespace .
*
2021-01-19 16:15:40 +08:00
* An entry represents the smallest storage unit in NVS .
* Strings and blobs may occupy more than one entry .
* Note that to find out the total number of entries occupied by the namespace ,
2018-02-20 12:11:56 +05:00
* add one to the returned value used_entries ( if err is equal to ESP_OK ) .
* Because the name space entry takes one entry .
*
* \ code { c }
* // Example of nvs_get_used_entry_count() to get amount of all key-value pairs in one namespace:
2019-04-01 15:13:55 +01:00
* nvs_handle_t handle ;
2018-02-20 12:11:56 +05:00
* nvs_open ( " namespace1 " , NVS_READWRITE , & handle ) ;
* . . .
* size_t used_entries ;
* size_t total_entries_namespace ;
* if ( nvs_get_used_entry_count ( handle , & used_entries ) = = ESP_OK ) {
2021-01-19 16:15:40 +08:00
* // the total number of entries occupied by the namespace
2018-02-20 12:11:56 +05:00
* total_entries_namespace = used_entries + 1 ;
* }
* \ endcode
*
* @ param [ in ] handle Handle obtained from nvs_open function .
*
* @ param [ out ] used_entries Returns amount of used entries from a namespace .
*
*
* @ return
* - ESP_OK if the changes have been written successfully .
* Return param used_entries will be filled valid value .
* - ESP_ERR_NVS_NOT_INITIALIZED if the storage driver is not initialized .
* Return param used_entries will be filled 0.
* - ESP_ERR_NVS_INVALID_HANDLE if handle has been closed or is NULL .
* Return param used_entries will be filled 0.
2023-10-19 14:36:10 +02:00
* - ESP_ERR_INVALID_ARG if used_entries is equal to NULL .
2018-02-20 12:11:56 +05:00
* - Other error codes from the underlying storage driver .
* Return param used_entries will be filled 0.
*/
2019-04-01 15:13:55 +01:00
esp_err_t nvs_get_used_entry_count ( nvs_handle_t handle , size_t * used_entries ) ;
2016-08-17 23:08:22 +08:00
2018-11-05 09:03:04 +01:00
/**
* @ brief Create an iterator to enumerate NVS entries based on one or more parameters
*
* \ code { c }
* // Example of listing all the key-value pairs of any type under specified partition and namespace
2022-05-11 18:49:55 +08:00
* nvs_iterator_t it = NULL ;
* esp_err_t res = nvs_entry_find ( < nvs_partition_name > , < namespace > , NVS_TYPE_ANY , & it ) ;
* while ( res = = ESP_OK ) {
* nvs_entry_info_t info ;
* nvs_entry_info ( it , & info ) ; // Can omit error check if parameters are guaranteed to be non-NULL
* printf ( " key '%s', type '%d' \n " , info . key , info . type ) ;
* res = nvs_entry_next ( & it ) ;
* }
* nvs_release_iterator ( it ) ;
2018-11-05 09:03:04 +01:00
* \ endcode
*
* @ param [ in ] part_name Partition name
*
* @ param [ in ] namespace_name Set this value if looking for entries with
* a specific namespace . Pass NULL otherwise .
*
* @ param [ in ] type One of nvs_type_t values .
*
2022-05-11 18:49:55 +08:00
* @ param [ out ] output_iterator
* Set to a valid iterator to enumerate all the entries found .
* Set to NULL if no entry for specified criteria was found .
* If any other error except ESP_ERR_INVALID_ARG occurs , \ c output_iterator is NULL , too .
* If ESP_ERR_INVALID_ARG occurs , \ c output_iterator is not changed .
* If a valid iterator is obtained through this function , it has to be released
* using \ c nvs_release_iterator when not used any more , unless ESP_ERR_INVALID_ARG is returned .
*
2018-11-05 09:03:04 +01:00
* @ return
2022-05-11 18:49:55 +08:00
* - ESP_OK if no internal error or programming error occurred .
* - ESP_ERR_NVS_NOT_FOUND if no element of specified criteria has been found .
* - ESP_ERR_NO_MEM if memory has been exhausted during allocation of internal structures .
* - ESP_ERR_INVALID_ARG if any of the parameters is NULL .
* Note : don ' t release \ c output_iterator in case ESP_ERR_INVALID_ARG has been returned
2018-11-05 09:03:04 +01:00
*/
2022-05-11 18:49:55 +08:00
esp_err_t nvs_entry_find ( const char * part_name ,
const char * namespace_name ,
nvs_type_t type ,
nvs_iterator_t * output_iterator ) ;
2018-11-05 09:03:04 +01:00
2023-04-03 16:48:02 -04:00
/**
* @ brief Create an iterator to enumerate NVS entries based on a handle and type
*
* \ code { c }
* // Example of listing all the key-value pairs of any type under specified handle (which defines a partition and namespace)
* nvs_iterator_t it = NULL ;
* esp_err_t res = nvs_entry_find_in_handle ( < nvs_handle > , NVS_TYPE_ANY , & it ) ;
* while ( res = = ESP_OK ) {
* nvs_entry_info_t info ;
* nvs_entry_info ( it , & info ) ; // Can omit error check if parameters are guaranteed to be non-NULL
* printf ( " key '%s', type '%d' \n " , info . key , info . type ) ;
* res = nvs_entry_next ( & it ) ;
* }
* nvs_release_iterator ( it ) ;
* \ endcode
*
* @ param [ in ] handle Handle obtained from nvs_open function .
*
* @ param [ in ] type One of nvs_type_t values .
*
* @ param [ out ] output_iterator
* Set to a valid iterator to enumerate all the entries found .
* Set to NULL if no entry for specified criteria was found .
* If any other error except ESP_ERR_INVALID_ARG occurs , \ c output_iterator is NULL , too .
* If ESP_ERR_INVALID_ARG occurs , \ c output_iterator is not changed .
* If a valid iterator is obtained through this function , it has to be released
* using \ c nvs_release_iterator when not used any more , unless ESP_ERR_INVALID_ARG is returned .
*
* @ return
* - ESP_OK if no internal error or programming error occurred .
* - ESP_ERR_NVS_NOT_FOUND if no element of specified criteria has been found .
* - ESP_ERR_NO_MEM if memory has been exhausted during allocation of internal structures .
2023-08-29 16:05:02 +02:00
* - ESP_ERR_NVS_INVALID_HANDLE if unknown handle was specified .
* - ESP_ERR_INVALID_ARG if output_iterator parameter is NULL .
2023-04-03 16:48:02 -04:00
* Note : don ' t release \ c output_iterator in case ESP_ERR_INVALID_ARG has been returned
*/
2023-04-13 16:06:05 +02:00
esp_err_t nvs_entry_find_in_handle ( nvs_handle_t handle , nvs_type_t type , nvs_iterator_t * output_iterator ) ;
2023-04-03 16:48:02 -04:00
2018-11-05 09:03:04 +01:00
/**
2022-05-11 18:49:55 +08:00
* @ brief Advances the iterator to next item matching the iterator criteria .
2018-11-05 09:03:04 +01:00
*
* Note that any copies of the iterator will be invalid after this call .
*
2023-04-03 16:48:02 -04:00
* @ param [ inout ] iterator Iterator obtained from nvs_entry_find or nvs_entry_find_in_handle
* function . Must be non - NULL . If any error except ESP_ERR_INVALID_ARG
* occurs , \ c iterator is set to NULL . If ESP_ERR_INVALID_ARG occurs , \ c
* iterator is not changed .
2018-11-05 09:03:04 +01:00
*
* @ return
2022-05-11 18:49:55 +08:00
* - ESP_OK if no internal error or programming error occurred .
* - ESP_ERR_NVS_NOT_FOUND if no next element matching the iterator criteria .
* - ESP_ERR_INVALID_ARG if \ c iterator is NULL .
* - Possibly other errors in the future for internal programming or flash errors .
2018-11-05 09:03:04 +01:00
*/
2022-05-11 18:49:55 +08:00
esp_err_t nvs_entry_next ( nvs_iterator_t * iterator ) ;
2018-11-05 09:03:04 +01:00
/**
* @ brief Fills nvs_entry_info_t structure with information about entry pointed to by the iterator .
*
2023-04-03 16:48:02 -04:00
* @ param [ in ] iterator Iterator obtained from nvs_entry_find or nvs_entry_find_in_handle
* function . Must be non - NULL .
2018-11-05 09:03:04 +01:00
*
* @ param [ out ] out_info Structure to which entry information is copied .
2022-05-11 18:49:55 +08:00
*
* @ return
* - ESP_OK if all parameters are valid ; current iterator data has been written to out_info
* - ESP_ERR_INVALID_ARG if one of the parameters is NULL .
2018-11-05 09:03:04 +01:00
*/
2022-05-11 18:49:55 +08:00
esp_err_t nvs_entry_info ( const nvs_iterator_t iterator , nvs_entry_info_t * out_info ) ;
2018-11-05 09:03:04 +01:00
/**
* @ brief Release iterator
*
2023-04-03 16:48:02 -04:00
* @ param [ in ] iterator Release iterator obtained from nvs_entry_find or
* nvs_entry_find_in_handle or nvs_entry_next function . NULL argument is
* allowed .
2018-11-05 09:03:04 +01:00
*
*/
void nvs_release_iterator ( nvs_iterator_t iterator ) ;
2016-08-17 23:08:22 +08:00
# ifdef __cplusplus
} // extern "C"
# endif
# endif //ESP_NVS_H