2018-10-03 18:09:59 +08:00
|
|
|
/* Finding Partitions Example
|
|
|
|
This example code is in the Public Domain (or CC0 licensed, at your option.)
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, this
|
|
|
|
software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
|
|
|
CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
#include <assert.h>
|
|
|
|
#include "esp_partition.h"
|
|
|
|
#include "esp_log.h"
|
|
|
|
|
|
|
|
static const char *TAG = "example";
|
|
|
|
|
|
|
|
// Get the string name of type enum values used in this example
|
|
|
|
static const char* get_type_str(esp_partition_type_t type)
|
|
|
|
{
|
|
|
|
switch(type) {
|
|
|
|
case ESP_PARTITION_TYPE_APP:
|
|
|
|
return "ESP_PARTITION_TYPE_APP";
|
|
|
|
case ESP_PARTITION_TYPE_DATA:
|
|
|
|
return "ESP_PARTITION_TYPE_DATA";
|
|
|
|
default:
|
|
|
|
return "UNKNOWN_PARTITION_TYPE"; // type not used in this example
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get the string name of subtype enum values used in this example
|
|
|
|
static const char* get_subtype_str(esp_partition_subtype_t subtype)
|
|
|
|
{
|
|
|
|
switch(subtype) {
|
|
|
|
case ESP_PARTITION_SUBTYPE_DATA_NVS:
|
|
|
|
return "ESP_PARTITION_SUBTYPE_DATA_NVS";
|
|
|
|
case ESP_PARTITION_SUBTYPE_DATA_PHY:
|
|
|
|
return "ESP_PARTITION_SUBTYPE_DATA_PHY";
|
|
|
|
case ESP_PARTITION_SUBTYPE_APP_FACTORY:
|
|
|
|
return "ESP_PARTITION_SUBTYPE_APP_FACTORY";
|
|
|
|
case ESP_PARTITION_SUBTYPE_DATA_FAT:
|
|
|
|
return "ESP_PARTITION_SUBTYPE_DATA_FAT";
|
|
|
|
default:
|
|
|
|
return "UNKNOWN_PARTITION_SUBTYPE"; // subtype not used in this example
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Find the partition using given parameters
|
|
|
|
static void find_partition(esp_partition_type_t type, esp_partition_subtype_t subtype, const char* name)
|
|
|
|
{
|
|
|
|
ESP_LOGI(TAG, "Find partition with type %s, subtype %s, label %s...", get_type_str(type), get_subtype_str(subtype),
|
|
|
|
name == NULL ? "NULL (unspecified)" : name);
|
2021-01-25 09:37:23 +00:00
|
|
|
|
2020-11-10 18:40:01 +11:00
|
|
|
const esp_partition_t * part = esp_partition_find_first(type, subtype, name);
|
2021-01-25 09:37:23 +00:00
|
|
|
|
2021-01-25 20:11:06 +08:00
|
|
|
if (part != NULL) {
|
2021-01-25 09:37:23 +00:00
|
|
|
ESP_LOGI(TAG, "\tfound partition '%s' at offset 0x%x with size 0x%x", part->label, part->address, part->size);
|
|
|
|
} else {
|
|
|
|
ESP_LOGE(TAG, "\tpartition not found!");
|
|
|
|
}
|
2018-10-03 18:09:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void app_main(void)
|
|
|
|
{
|
2020-11-10 18:40:01 +11:00
|
|
|
/*
|
2018-10-03 18:09:59 +08:00
|
|
|
* This example uses the partition table from ../partitions_example.csv. For reference, its contents are as follows:
|
2020-11-10 18:40:01 +11:00
|
|
|
*
|
2018-10-03 18:09:59 +08:00
|
|
|
* nvs, data, nvs, 0x9000, 0x6000,
|
|
|
|
* phy_init, data, phy, 0xf000, 0x1000,
|
|
|
|
* factory, app, factory, 0x10000, 1M,
|
|
|
|
* storage1, data, fat, , 0x40000,
|
|
|
|
* storage2, data, fat, , 0x40000,
|
2020-11-10 18:40:01 +11:00
|
|
|
*
|
2018-10-03 18:09:59 +08:00
|
|
|
* Display the partition table to the user for reference.
|
|
|
|
*/
|
|
|
|
extern const char csv_start[] asm("_binary_partitions_example_csv_start");
|
|
|
|
extern const char csv_end[] asm("_binary_partitions_example_csv_end");
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "Printing partition table csv file contents for reference...\n\n%.*s", csv_end - csv_start + 1, csv_start);
|
|
|
|
|
|
|
|
/* First Part - Finding partitions using esp_partition_find_first. */
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "----------------Find partitions---------------");
|
|
|
|
|
|
|
|
// Find partitions using esp_partition_find_first(). This returns the first partition matching the passed constraints.
|
|
|
|
find_partition(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_DATA_NVS, NULL);
|
|
|
|
find_partition(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_DATA_PHY, NULL);
|
|
|
|
find_partition(ESP_PARTITION_TYPE_APP, ESP_PARTITION_SUBTYPE_APP_FACTORY, NULL);
|
|
|
|
|
|
|
|
find_partition(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_DATA_FAT, NULL);
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "Find second FAT partition by specifying the label");
|
|
|
|
// In case of multiple matches, `esp_partition_find_first` returns the first match.
|
|
|
|
find_partition(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_DATA_FAT, "storage2");
|
|
|
|
|
|
|
|
/* Second Part - Iterating over partitions */
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "----------------Iterate through partitions---------------");
|
2020-11-10 18:40:01 +11:00
|
|
|
|
2018-10-03 18:09:59 +08:00
|
|
|
esp_partition_iterator_t it;
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "Iterating through app partitions...");
|
|
|
|
it = esp_partition_find(ESP_PARTITION_TYPE_APP, ESP_PARTITION_SUBTYPE_ANY, NULL);
|
|
|
|
|
2020-11-10 18:40:01 +11:00
|
|
|
// Loop through all matching partitions, in this case, all with the type 'data' until partition with desired
|
2018-10-03 18:09:59 +08:00
|
|
|
// label is found. Verify if its the same instance as the one found before.
|
|
|
|
for (; it != NULL; it = esp_partition_next(it)) {
|
|
|
|
const esp_partition_t *part = esp_partition_get(it);
|
|
|
|
ESP_LOGI(TAG, "\tfound partition '%s' at offset 0x%x with size 0x%x", part->label, part->address, part->size);
|
|
|
|
}
|
|
|
|
// Release the partition iterator to release memory allocated for it
|
|
|
|
esp_partition_iterator_release(it);
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "Iterating through data partitions...");
|
|
|
|
it = esp_partition_find(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_ANY, NULL);
|
|
|
|
|
2020-11-10 18:40:01 +11:00
|
|
|
// Loop through all matching partitions, in this case, all with the type 'data' until partition with desired
|
2018-10-03 18:09:59 +08:00
|
|
|
// label is found. Verify if its the same instance as the one found before.
|
|
|
|
for (; it != NULL; it = esp_partition_next(it)) {
|
|
|
|
const esp_partition_t *part = esp_partition_get(it);
|
|
|
|
ESP_LOGI(TAG, "\tfound partition '%s' at offset 0x%x with size 0x%x", part->label, part->address, part->size);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Release the partition iterator to release memory allocated for it
|
|
|
|
esp_partition_iterator_release(it);
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "Example end");
|
|
|
|
}
|