1. 为什么你需要关心ESP32的分区表?
如果你刚开始玩ESP32,可能会觉得分区表这东西有点“玄学”——不就是把一块Flash内存切成几块吗?默认配置用用不就行了?我以前也是这么想的,直到在一个实际项目里栽了跟头。那个项目需要存储大量的传感器历史数据,同时还要支持OTA(空中升级)功能。我用默认的“双OTA分区”配置编译完程序,一上电就懵了:系统提示NVS存储空间不足,数据存不进去;想增大NVS分区吧,OTA分区又没地方了。最后产品功能受限,不得不回炉重造。
这次经历让我彻底明白,分区表绝不是一份可有可无的“摆设”,它是ESP32系统存储空间的“城市规划图”。想象一下,一座城市如果没有合理的规划,工业区、住宅区、绿化带胡乱堆在一起,结果就是交通拥堵、生活不便、发展受限。ESP32那宝贵的几MB Flash也是如此。默认的分区方案就像一份通用的城市模板,它可能适合大多数简单应用,但一旦你的项目有点“个性”——比如需要更大的文件系统、更多的OTA备份、或者要存放大量的配置参数——这份模板就捉襟见肘了。
自定义分区表,就是让你成为自己项目的“总规划师”。你可以根据应用的实际需求,精细地划分每一块“土地”的用途和大小。是给数据存储多留点空间,还是为未来的功能升级预留余地?是把关键参数放在最安全的位置,还是优化启动速度?这些决策都体现在那张小小的CSV文件里。掌握它,你就能从“被动适应硬件”变为“主动驾驭硬件”,真正榨干ESP32每一KB存储的潜力,让系统跑得更稳、更高效。接下来,我就带你从零开始,彻底搞懂这张“地图”该怎么画。
2. 分区表基础:拆解CSV文件的每一列
ESP32的分区表本质上是一个CSV(逗号分隔值)文件。别看它格式简单,里面每一列都藏着关键信息。我们先来看一个最经典的双OTA分区表示例,我会一行一行拆开讲:
# 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,
第一列:Name(名称) 这就像你给每个分区起的“外号”,方便你在代码里通过名字找到它。比如你用 esp_partition_find_first(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_DATA_NVS, "nvs") 就能快速定位到NVS分区。名字最好起得有意义,比如sensor_data、web_config,但别超过16个字符,超了的部分会被截掉。我习惯用英文小写加下划线,清晰又好记。
第二列:Type(类型) 这是分区的“根本属性”,主要就两种:app 和 data。
app类型(十六进制0x00):这是存放可执行程序的地方,也就是你编译出来的固件(.bin文件)烧录的位置。ESP32上电后,启动加载器(Bootloader)就是从这里找代码执行的。data类型(十六进制0x01):这是存放数据的地方。像Wi-Fi密码、设备配置、传感器日志这些,都归data分区管。 你甚至可以不用这两个预定义词,直接填0x40到0xFE之间的数字,来创建你自己的自定义类型,方便扩展。但记住,0x00到0x3F是ESP-IDF的“保留地”,咱们别去占用。
第三列:SubType(子类型) 这是在Type基础上的进一步细分,决定了分区具体的“职业”。
- 对于
app类型:factory(0x00):出厂应用程序分区。这是Bootloader默认会去启动的分区。但有个关键点:一旦你启用了OTA功能,并且otadata分区里记录了有效的OTA信息,Bootloader就会优先启动OTA分区,而不是factory。而且,OTA升级永远不会动factory分区。所以很多优化方案里,会直接删掉factory分区,把空间省出来给ota_0用。ota_0到ota_15(0x10-0x1F):OTA应用程序分区。支持OTA的项目至少需要两个(比如ota_0和ota_1),一个用来运行当前版本,另一个用来下载和验证新版本,实现无缝切换。
- 对于
data类型:nvs(0x02):非易失性存储分区。这是ESP-IDF里一个超级实用的键值对存储系统。你的Wi-Fi配置、蓝牙配对信息、设备校准参数,默认都存在这里


974

被折叠的 条评论
为什么被折叠?



