ESP32——数组或结构体等类型数据掉电保存(分区表方式)

内容主要来源于乐鑫官网

在使用分区表时,需打开项目配置菜单(VSCODE 的SDK Configuration editor)

 有下面3个选项

  • “Single factory app, no OTA”

  • “Factory app, two OTA definitions”

  • “Custom partition table CSV”

以下是 “Single factory app, no OTA” 选项的分区表信息摘要:

# ESP-IDF Partition Table
# Name,   Type, SubType, Offset,  Size,   Flags
nvs,      data, nvs,     0x9000,  0x6000,
phy_init, data, phy,     0xf000,  0x1000,
factory,  app,  factory, 0x10000, 1M,
  • flash 的 0x10000 (64 KB) 偏移地址处存放一个标记为 “factory” 的二进制应用程序,且启动加载器将默认加载这个应用程序。

  • 分区表中还定义了两个数据区域,分别用于存储 NVS 库专用分区和 PHY 初始化数据。

以下是 “Factory app, two OTA definitions” 选项的分区表信息摘要:

# ESP-IDF Partition Table
# Name,   Type, SubType, Offset,  Size, Flags
nvs,      data, nvs,     0x9000,  0x4000,
otadata,  data, ota,     0xd000,  0x2000,
phy_init, data, phy,     0xf000,  0x1000,
factory,  app,  factory, 0x10000,  1M,
ota_0,    app,  ota_0,   0x110000, 1M,
ota_1,    app,  ota_1,   0x210000, 1M,
  • 分区表中定义了三个应用程序分区,这三个分区的类型都被设置为 “app”,但具体 app 类型不同。其中,位于 0x10000 偏移地址处的为出厂应用程序(factory),其余两个为 OTA 应用程序(ota_0,ota_1)。

  • 新增了一个名为 “otadata” 的数据分区,用于保存 OTA 升级时需要的数据。启动加载器会查询该分区的数据,以判断该从哪个 OTA 应用程序分区加载程序。如果 “otadata” 分区为空,则会执行出厂程序。

“Custom partition table CSV”,为自定义分区表,需要修改对应CSV文件,此种方法不如上面两种常用。

代码示例:

    const esp_partition_t *partition = esp_partition_find_first(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_DATA_NVS, NULL);
    assert(partition != NULL);
    id[]={0xE2,0x01,0xD2,0x11,0x73,0x41,0x00,0x78,0x85,0x51,0x00,0x00};
    ESP_ERROR_CHECK(esp_partition_erase_range(partition, 0, partition->size));//SPI_FLASH_SEC_SIZE));
    ESP_ERROR_CHECK(esp_partition_write(partition, 0, id, 12));
    ESP_ERROR_CHECK(esp_partition_read(partition, 0, read_data, 12));

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要从ESP32的NVS(Non-Volatile Storage)中读取结构体数组,您可以按照以下步骤进行操作: 1. 确保您已经在ESP32上初始化了NVS。可以使用ESP-IDF提供的API或者ESP32 Arduino库中的相关函数来实现这一步骤。 2. 定义您的结构体数组,并确保每个结构体都是可序列化的。这意味着结构体中的所有成员变量都是基本数据类型或者可序列化的自定义类型。 3. 使用NVS API从NVS中读取结构体数组。以下是一个示例代码片段: ```c #include <nvs.h> typedef struct { int value1; float value2; // 其他成员变量... } MyStruct; #define STORAGE_NAMESPACE "storage" void readStructArray(MyStruct* array, size_t size) { nvs_handle_t nvsHandle; esp_err_t err = nvs_open(STORAGE_NAMESPACE, NVS_READONLY, &nvsHandle); if (err != ESP_OK) { // 错误处理 return; } size_t requiredSize = 0; err = nvs_get_blob(nvsHandle, "array", NULL, &requiredSize); if (err != ESP_OK) { // 错误处理 return; } if (requiredSize != size * sizeof(MyStruct)) { // 错误处理:存储的数据大小与期望的大小不匹配 return; } err = nvs_get_blob(nvsHandle, "array", array, &requiredSize); if (err != ESP_OK) { // 错误处理 return; } nvs_close(nvsHandle); } ``` 在上述示例中,我们首先使用`nvs_get_blob`函数的第一次调用来获取存储的结构体数组的大小。然后,我们检查获取的大小是否与期望的大小匹配。最后,我们使用`nvs_get_blob`函数的第二次调用来实际获取存储的结构体数组数据。 4. 现在,您可以通过`array`参数访问恢复的结构体数组数据。 希望这些信息对您有所帮助!如果您有任何其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值