2016-11-15 05:24:56 -05:00
|
|
|
// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2020-11-10 02:40:01 -05:00
|
|
|
|
2016-11-15 05:24:56 -05:00
|
|
|
#include "nvs_flash.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize NVS flash storage with custom flash sector layout
|
|
|
|
*
|
|
|
|
* @note This API is intended to be used in unit tests.
|
2020-11-10 02:40:01 -05:00
|
|
|
*
|
2017-08-21 05:56:16 -04:00
|
|
|
* @param partName Partition name of the NVS partition as per partition table
|
2016-11-15 05:24:56 -05:00
|
|
|
* @param baseSector Flash sector (units of 4096 bytes) offset to start NVS
|
2020-11-10 02:40:01 -05:00
|
|
|
* @param sectorCount Length (in flash sectors) of NVS region.
|
2016-11-15 05:24:56 -05:00
|
|
|
NVS partition must be at least 3 sectors long.
|
|
|
|
* @return ESP_OK if flash was successfully initialized
|
|
|
|
*/
|
2017-08-21 05:56:16 -04:00
|
|
|
esp_err_t nvs_flash_init_custom(const char *partName, uint32_t baseSector, uint32_t sectorCount);
|
2016-11-15 05:24:56 -05:00
|
|
|
|
2018-07-02 07:10:43 -04:00
|
|
|
#ifdef CONFIG_NVS_ENCRYPTION
|
|
|
|
/**
|
|
|
|
* @brief Initialize NVS flash storage with custom flash sector layout
|
|
|
|
*
|
|
|
|
* @note This API is intended to be used in unit tests.
|
2020-11-10 02:40:01 -05:00
|
|
|
*
|
2018-07-02 07:10:43 -04:00
|
|
|
* @param partName Partition name of the NVS partition as per partition table
|
|
|
|
* @param baseSector Flash sector (units of 4096 bytes) offset to start NVS
|
2020-11-10 02:40:01 -05:00
|
|
|
* @param sectorCount Length (in flash sectors) of NVS region.
|
2018-07-02 07:10:43 -04:00
|
|
|
NVS partition must be at least 3 sectors long.
|
2020-11-10 02:40:01 -05:00
|
|
|
* @param[in] cfg Security configuration (keys) to be used for NVS encryption/decryption.
|
|
|
|
* If cfg is null, no encryption/decryption is used.
|
2018-07-02 07:10:43 -04:00
|
|
|
* @return ESP_OK if flash was successfully initialized
|
|
|
|
*/
|
|
|
|
esp_err_t nvs_flash_secure_init_custom(const char *partName, uint32_t baseSector, uint32_t sectorCount, nvs_sec_cfg_t* cfg);
|
|
|
|
#endif
|
2016-11-15 05:24:56 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Dump contents of NVS storage to stdout
|
|
|
|
*
|
|
|
|
* This function may be used for debugging purposes to inspect the state
|
|
|
|
* of NVS pages. For each page, list of entries is also dumped.
|
2017-08-21 05:56:16 -04:00
|
|
|
*
|
|
|
|
* @param partName Partition name of the NVS partition as per partition table
|
2016-11-15 05:24:56 -05:00
|
|
|
*/
|
2017-08-21 05:56:16 -04:00
|
|
|
void nvs_dump(const char *partName);
|
2016-11-15 05:24:56 -05:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|