From d7fa288a6c957c0e53f9ae5adeec62d0589bbd86 Mon Sep 17 00:00:00 2001 From: KonstantinKondrashov Date: Thu, 15 Aug 2019 18:41:28 +0800 Subject: [PATCH] examples: Add an example efuse API usage Added: read, write operations for the common and custom efuse tables. Writing is possible only for CONFIG_EFUSE_VIRTUAL. Closes: IDF-773 --- examples/system/efuse/CMakeLists.txt | 6 + examples/system/efuse/Makefile | 9 + examples/system/efuse/README.md | 184 ++++++++++++++++++ examples/system/efuse/main/CMakeLists.txt | 4 + examples/system/efuse/main/component.mk | 5 + examples/system/efuse/main/efuse_main.c | 155 +++++++++++++++ .../efuse/main/esp_efuse_custom_table.c | 81 ++++++++ .../efuse/main/esp_efuse_custom_table.csv | 18 ++ .../main/include/esp_efuse_custom_table.h | 36 ++++ examples/system/efuse/sdkconfig.defaults | 2 + 10 files changed, 500 insertions(+) create mode 100644 examples/system/efuse/CMakeLists.txt create mode 100644 examples/system/efuse/Makefile create mode 100644 examples/system/efuse/README.md create mode 100644 examples/system/efuse/main/CMakeLists.txt create mode 100644 examples/system/efuse/main/component.mk create mode 100644 examples/system/efuse/main/efuse_main.c create mode 100644 examples/system/efuse/main/esp_efuse_custom_table.c create mode 100644 examples/system/efuse/main/esp_efuse_custom_table.csv create mode 100644 examples/system/efuse/main/include/esp_efuse_custom_table.h create mode 100644 examples/system/efuse/sdkconfig.defaults diff --git a/examples/system/efuse/CMakeLists.txt b/examples/system/efuse/CMakeLists.txt new file mode 100644 index 000000000..426bdbf41 --- /dev/null +++ b/examples/system/efuse/CMakeLists.txt @@ -0,0 +1,6 @@ +# The following lines of boilerplate have to be in your project's CMakeLists +# in this exact order for cmake to work correctly +cmake_minimum_required(VERSION 3.5) + +include($ENV{IDF_PATH}/tools/cmake/project.cmake) +project(efuse) diff --git a/examples/system/efuse/Makefile b/examples/system/efuse/Makefile new file mode 100644 index 000000000..3a781495a --- /dev/null +++ b/examples/system/efuse/Makefile @@ -0,0 +1,9 @@ +# +# This is a project Makefile. It is assumed the directory this Makefile resides in is a +# project subdirectory. +# + +PROJECT_NAME := efuse + +include $(IDF_PATH)/make/project.mk + diff --git a/examples/system/efuse/README.md b/examples/system/efuse/README.md new file mode 100644 index 000000000..39315b6c5 --- /dev/null +++ b/examples/system/efuse/README.md @@ -0,0 +1,184 @@ +# eFuse Example + +## Overview + +This example shows how to use the eFuse API. It demonstrates read and write operations with fields from the common and custom eFuse tables. For more information about eFuse, see the “eFuse Manager” chapter in the documentation and the “eFuse Controller” chapter in ESP32 TRM. + +The eFuse is a single bit of non-volatile memory with the restriction that once an eFuse bit is programmed to 1, it can not be reverted to 0. +The eFuse fields can be useful to store: device types, serial numbers, some system variables, etc. + +Note that the bits already written cannot be reset to the original state. For debugging purposes, the `CONFIG_EFUSE_VIRTUAL` option is provided. This option will block physical burning. All work happens with an array in RAM. +In this example, all write operations are wrapped in `#ifdef CONFIG_EFUSE_VIRTUAL ... # endif` to prevent accidental burn while testing the features. + +## How to use example + +This example first reads the eFuse field, then writes a value, then reads it again. The program can be seen in the logs. + +The program uses two eFuse tables: + + * The common table (for IDF purposes). + * The custom table (for custom purposes). + +The custom table has five fields: + +``` +MODULE_VERSION, EFUSE_BLK3, 56, 8, Module version +DEVICE_ROLE, EFUSE_BLK3, 64, 3, Device role +SETTING_1, EFUSE_BLK3, 67, 6, Setting 1 +SETTING_2, EFUSE_BLK3, 73, 5, Setting 2 +CUSTOM_SECURE_VERSION, EFUSE_BLK3, 78, 16, Custom secure version +``` + +### Hardware Required + +To run this example, you need to use the ESP32 developer board. If your ESP32 has the `None` coding scheme of eFuse, then write and read operations have no limitations. But if it has the `3/4` or `RS` coding scheme, the writing may lead to an error due to the fact that some coded value was written earlier. A simple way to find out what coding scheme your chip has, you can see in the log while esptool is working or the log of the program: + +``` +esptool.py v2.7-dev +Serial port /dev/ttyUSB0 +Connecting........_____.....__ +Detecting chip type... ESP32 +Chip is ESP32-PICO-D4 (revision 1) +Features: WiFi, BT, Dual Core, Embedded Flash, Coding Scheme None +MAC: d8:a0:1d:40:ac:90 +``` + +The esptool also has a command to get general information about the chip `esptool.py chip_id`: + +``` +esptool.py v2.8-dev +Found 1 serial ports +Serial port /dev/ttyUSB0 +Connecting........_ +Detecting chip type... ESP32 +Chip is ESP32-PICO-D4 (revision 1) +Features: WiFi, BT, Dual Core, Embedded Flash, Coding Scheme None +Crystal is 40MHz +MAC: d8:a0:1d:40:ac:90 +Uploading stub... +Running stub... +Stub running... +Warning: ESP32 has no Chip ID. Reading MAC instead. +MAC: d8:a0:1d:40:ac:90 +Hard resetting via RTS pin... +``` + +### Configure the project + +``` +idf.py menuconfig +``` + +In this example, there is `sdkconfig.default`, which already includes all the necessary settings. No need to configure. + + * `CONFIG_EFUSE_CUSTOM_TABLE=y` - It allows using the custom table. + * `CONFIG_EFUSE_VIRTUAL=y` - All read and writes operations are redirected to RAM instead of eFuse registers. Not really burning eFuses. + +### Build and Flash + +Build the project and flash it to the board, then run monitor tool to view serial output: + +``` +idf.py -p PORT flash monitor +``` + +(Replace PORT with the name of the serial port to use.) + +(To exit the serial monitor, type ``Ctrl-]``.) + +See the Getting Started Guide for full steps to configure and use ESP-IDF to build projects. + + +## Example Output + +For ``None`` coding scheme: + + +``` +I (0) cpu_start: Starting scheduler on APP CPU. +I (323) example: Coding Scheme NONE +I (323) example: Uses common and custom tables +I (333) example: read efuse fields +I (333) example: 1. read MAC address: d8:a0:1d:40:ac:90 +I (343) example: 2. read secure_version: 0 +I (343) example: 3. read custom fields +I (353) example: module_version = 0 +I (353) example: device_role = None +I (363) example: setting_1 = 0 +I (363) example: setting_2 = 0 +I (363) example: custom_secure_version = 0 +W (373) example: This example does not burn any efuse in reality only virtually +W (383) example: Write operations in efuse fields are performed virtually +I (383) example: write custom efuse fields +W (393) efuse: Virtual efuses enabled: Not really burning eFuses +W (403) efuse: Virtual efuses enabled: Not really burning eFuses +W (403) efuse: Virtual efuses enabled: Not really burning eFuses +W (413) efuse: Virtual efuses enabled: Not really burning eFuses +W (423) efuse: Virtual efuses enabled: Not really burning eFuses +I (423) example: module_version = 1 +I (433) example: device_role = Slave +I (433) example: setting_1 = 3 +I (433) example: setting_2 = 4 +I (443) example: custom_secure_version = 5 +I (443) example: Done +``` + +And for ``3/4`` coding scheme: + + +``` +I (0) cpu_start: Starting scheduler on APP CPU. +I (327) example: Coding Scheme 3/4 +I (327) example: Uses common and custom tables +I (337) example: read efuse fields +I (337) example: 1. read MAC address: 84:0d:8e:18:8e:44 +I (347) example: 2. read secure_version: 0 +I (347) example: 3. read custom fields +I (357) example: module_version = 0 +I (357) example: device_role = None +I (367) example: setting_1 = 0 +I (367) example: setting_2 = 0 +I (367) example: custom_secure_version = 0 +W (377) example: This example does not burn any efuse in reality only virtually +W (387) example: Write operations in efuse fields are performed virtually +I (387) example: In the case of 3/4 coding scheme, you cannot write efuse fields separately +I (397) example: You should use the batch mode of writing fields for this +I (407) efuse: Batch mode of writing fields is enabled +W (417) efuse: Virtual efuses enabled: Not really burning eFuses +I (417) efuse: Batch mode of writing fields is disabled +I (427) example: module_version = 1 +I (427) example: device_role = Slave +I (437) example: setting_1 = 3 +I (437) example: setting_2 = 4 +I (437) example: custom_secure_version = 5 +I (447) example: Done +``` + + +### How to create the new custom table + +In the main folder of the example there is a custom eFuse table - `esp_efuse_custom_table.csv`. You can add there some fields and run `idf.py efuse_custom_table`, it will generate all the necessary source files. If all is ok then you will see: + +``` +... +Parsing efuse CSV input file /home/kostia/esp/esp-idf/components/efuse/esp32/esp_efuse_table.csv ... +Verifying efuse table... +Parsing efuse CSV input file /home/kostia/esp/esp-idf/examples/system/efuse/main/esp_efuse_custom_table.csv ... +Verifying efuse table... +Creating efuse *.h file /home/kostia/esp/esp-idf/examples/system/efuse/main/include/esp_efuse_custom_table.h ... +Creating efuse *.c file /home/kostia/esp/esp-idf/examples/system/efuse/main/esp_efuse_custom_table.c ... +Max number of bits in BLK 192 +``` + +If the following fields were not changed in the CSV file: field_name, efuse_block, bit_start or bit_count, then a new generation will not occur, and you will see this message `Source files do not require updating correspond to csv file`. + +This command will create into main folder two files: `esp_efuse_custom_table.c` and `include/esp_efuse_custom_table.h`. + +Do not forget to add these files for the Cmake build system: + +``` +idf_component_register(SRCS "efuse_main.c" "esp_efuse_custom_table.c" + INCLUDE_DIRS "." "include") +``` + +If you are not sure which eFuse bits are free you can run `idf.py show_efuse_table`. It prints a sorted list of the common and custom tables. diff --git a/examples/system/efuse/main/CMakeLists.txt b/examples/system/efuse/main/CMakeLists.txt new file mode 100644 index 000000000..00c6c787b --- /dev/null +++ b/examples/system/efuse/main/CMakeLists.txt @@ -0,0 +1,4 @@ +idf_component_register(SRCS "efuse_main.c" + "esp_efuse_custom_table.c" + INCLUDE_DIRS "." + "include") \ No newline at end of file diff --git a/examples/system/efuse/main/component.mk b/examples/system/efuse/main/component.mk new file mode 100644 index 000000000..0b9d7585e --- /dev/null +++ b/examples/system/efuse/main/component.mk @@ -0,0 +1,5 @@ +# +# "main" pseudo-component makefile. +# +# (Uses default behaviour of compiling all source files in directory, adding 'include' to include path.) + diff --git a/examples/system/efuse/main/efuse_main.c b/examples/system/efuse/main/efuse_main.c new file mode 100644 index 000000000..7f0075eeb --- /dev/null +++ b/examples/system/efuse/main/efuse_main.c @@ -0,0 +1,155 @@ +/* efuse 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 +#include "freertos/FreeRTOS.h" +#include "freertos/task.h" +#include "esp_err.h" +#include "esp_log.h" +#include "esp_efuse.h" +#include "esp_efuse_table.h" +#include "esp_efuse_custom_table.h" +#include "sdkconfig.h" + +static const char* TAG = "example"; + + +typedef struct { + uint8_t module_version; /*!< Module version: length 8 bits */ + uint8_t device_role; /*!< Device role: length 3 bits */ + uint8_t setting_1; /*!< Setting 1: length 6 bits */ + uint8_t setting_2; /*!< Setting 2: length 5 bits */ + size_t custom_secure_version; /*!< Custom secure version: length 16 bits */ + uint16_t reserv; /*!< Reserv */ +} device_desc_t; + + +static void print_device_desc(device_desc_t *desc) +{ + ESP_LOGI(TAG, "module_version = %d", desc->module_version); + if (desc->device_role == 0) { + ESP_LOGI(TAG, "device_role = None"); + } else if (desc->device_role == 1) { + ESP_LOGI(TAG, "device_role = Master"); + } else if (desc->device_role == 2) { + ESP_LOGI(TAG, "device_role = Slave"); + } else { + ESP_LOGI(TAG, "device_role = Not supported"); + } + ESP_LOGI(TAG, "setting_1 = %d", desc->setting_1); + ESP_LOGI(TAG, "setting_2 = %d", desc->setting_2); + ESP_LOGI(TAG, "custom_secure_version = %d", desc->custom_secure_version); +} + + +static void read_device_desc_efuse_fields(device_desc_t *desc) +{ + ESP_ERROR_CHECK(esp_efuse_read_field_blob(ESP_EFUSE_MODULE_VERSION, &desc->module_version, 8)); + ESP_ERROR_CHECK(esp_efuse_read_field_blob(ESP_EFUSE_DEVICE_ROLE, &desc->device_role, 3)); + ESP_ERROR_CHECK(esp_efuse_read_field_blob(ESP_EFUSE_SETTING_1, &desc->setting_1, 6)); + ESP_ERROR_CHECK(esp_efuse_read_field_blob(ESP_EFUSE_SETTING_2, &desc->setting_2, 5)); + ESP_ERROR_CHECK(esp_efuse_read_field_cnt(ESP_EFUSE_CUSTOM_SECURE_VERSION, &desc->custom_secure_version)); + print_device_desc(desc); +} + + +static void read_efuse_fields(device_desc_t *desc) +{ + ESP_LOGI(TAG, "read efuse fields"); + + uint8_t mac[6]; + ESP_ERROR_CHECK(esp_efuse_read_field_blob(ESP_EFUSE_MAC_FACTORY, &mac, sizeof(mac) * 8)); + ESP_LOGI(TAG, "1. read MAC address: %02x:%02x:%02x:%02x:%02x:%02x", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]); + + size_t secure_version = 0; + ESP_ERROR_CHECK(esp_efuse_read_field_cnt(ESP_EFUSE_SECURE_VERSION, &secure_version)); + ESP_LOGI(TAG, "2. read secure_version: %d", secure_version); + + ESP_LOGI(TAG, "3. read custom fields"); + read_device_desc_efuse_fields(desc); +} + + +static void write_efuse_fields(device_desc_t *desc, esp_efuse_coding_scheme_t coding_scheme) +{ +#ifdef CONFIG_EFUSE_VIRTUAL + +#if CONFIG_IDF_TARGET_ESP32 + const esp_efuse_coding_scheme_t coding_scheme_for_batch_mode = EFUSE_CODING_SCHEME_3_4; +#else + const esp_efuse_coding_scheme_t coding_scheme_for_batch_mode = EFUSE_CODING_SCHEME_RS; +#endif + + ESP_LOGI(TAG, "write custom efuse fields"); + if (coding_scheme == coding_scheme_for_batch_mode) { + ESP_LOGI(TAG, "In the case of 3/4 or RS coding scheme, you cannot write efuse fields separately"); + ESP_LOGI(TAG, "You should use the batch mode of writing fields for this"); + ESP_ERROR_CHECK(esp_efuse_batch_write_begin()); + } + + ESP_ERROR_CHECK(esp_efuse_write_field_blob(ESP_EFUSE_MODULE_VERSION, &desc->module_version, 8)); + ESP_ERROR_CHECK(esp_efuse_write_field_blob(ESP_EFUSE_DEVICE_ROLE, &desc->device_role, 3)); + ESP_ERROR_CHECK(esp_efuse_write_field_blob(ESP_EFUSE_SETTING_1, &desc->setting_1, 6)); + ESP_ERROR_CHECK(esp_efuse_write_field_blob(ESP_EFUSE_SETTING_2, &desc->setting_2, 5)); + ESP_ERROR_CHECK(esp_efuse_write_field_cnt(ESP_EFUSE_CUSTOM_SECURE_VERSION, desc->custom_secure_version)); + + if (coding_scheme == coding_scheme_for_batch_mode) { + ESP_ERROR_CHECK(esp_efuse_batch_write_commit()); + } +#endif // CONFIG_EFUSE_VIRTUAL +} + + +static esp_efuse_coding_scheme_t get_coding_scheme(void) +{ + // The coding scheme is used for EFUSE_BLK1, EFUSE_BLK2 and EFUSE_BLK3. + // We use EFUSE_BLK3 (custom block) to verify it. + esp_efuse_coding_scheme_t coding_scheme = esp_efuse_get_coding_scheme(EFUSE_BLK3); + if (coding_scheme == EFUSE_CODING_SCHEME_NONE) { + ESP_LOGI(TAG, "Coding Scheme NONE"); +#if CONFIG_IDF_TARGET_ESP32 + } else if (coding_scheme == EFUSE_CODING_SCHEME_3_4) { + ESP_LOGI(TAG, "Coding Scheme 3/4"); + } else { + ESP_LOGI(TAG, "Coding Scheme REPEAT"); + } +#else + } else if (coding_scheme == EFUSE_CODING_SCHEME_RS) { + ESP_LOGI(TAG, "Coding Scheme RS (Reed-Solomon coding)"); + } +#endif + return coding_scheme; +} + + +void app_main(void) +{ + esp_efuse_coding_scheme_t coding_scheme = get_coding_scheme(); + + device_desc_t device_desc = { 0 }; + read_efuse_fields(&device_desc); + + ESP_LOGW(TAG, "This example does not burn any efuse in reality only virtually"); +#ifdef CONFIG_EFUSE_VIRTUAL + ESP_LOGW(TAG, "Write operations in efuse fields are performed virtually"); + if (device_desc.device_role == 0) { + device_desc.module_version = 1; + device_desc.device_role = 2; + device_desc.setting_1 = 3; + device_desc.setting_2 = 4; + device_desc.custom_secure_version = 5; + write_efuse_fields(&device_desc, coding_scheme); + read_device_desc_efuse_fields(&device_desc); + } +#else + ESP_LOGW(TAG, "The part of the code that writes efuse fields is disabled"); +#endif + + ESP_LOGI(TAG, "Done"); +} diff --git a/examples/system/efuse/main/esp_efuse_custom_table.c b/examples/system/efuse/main/esp_efuse_custom_table.c new file mode 100644 index 000000000..6375cf3a6 --- /dev/null +++ b/examples/system/efuse/main/esp_efuse_custom_table.c @@ -0,0 +1,81 @@ +// Copyright 2017-2018 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 + +#include "sdkconfig.h" +#include "esp_efuse.h" +#include +#include "esp_efuse_custom_table.h" + +// md5_digest_table 584317af6a850ee16ef6206c139d6cf5 +// This file was generated from the file esp_efuse_custom_table.csv. DO NOT CHANGE THIS FILE MANUALLY. +// If you want to change some fields, you need to change esp_efuse_custom_table.csv file +// then run `efuse_common_table` or `efuse_custom_table` command it will generate this file. +// To show efuse_table run the command 'show_efuse_table'. + +#define MAX_BLK_LEN CONFIG_EFUSE_MAX_BLK_LEN + +// The last free bit in the block is counted over the entire file. +#define LAST_FREE_BIT_BLK3 94 + +_Static_assert(LAST_FREE_BIT_BLK3 <= MAX_BLK_LEN, "The eFuse table does not match the coding scheme. Edit the table and restart the efuse_common_table or efuse_custom_table command to regenerate the new files."); + +static const esp_efuse_desc_t MODULE_VERSION[] = { + {EFUSE_BLK3, 56, 8}, // Module version, +}; + +static const esp_efuse_desc_t DEVICE_ROLE[] = { + {EFUSE_BLK3, 64, 3}, // Device role, +}; + +static const esp_efuse_desc_t SETTING_1[] = { + {EFUSE_BLK3, 67, 6}, // Setting 1, +}; + +static const esp_efuse_desc_t SETTING_2[] = { + {EFUSE_BLK3, 73, 5}, // Setting 2, +}; + +static const esp_efuse_desc_t CUSTOM_SECURE_VERSION[] = { + {EFUSE_BLK3, 78, 16}, // Custom secure version, +}; + + + + + +const esp_efuse_desc_t* ESP_EFUSE_MODULE_VERSION[] = { + &MODULE_VERSION[0], // Module version + NULL +}; + +const esp_efuse_desc_t* ESP_EFUSE_DEVICE_ROLE[] = { + &DEVICE_ROLE[0], // Device role + NULL +}; + +const esp_efuse_desc_t* ESP_EFUSE_SETTING_1[] = { + &SETTING_1[0], // Setting 1 + NULL +}; + +const esp_efuse_desc_t* ESP_EFUSE_SETTING_2[] = { + &SETTING_2[0], // Setting 2 + NULL +}; + +const esp_efuse_desc_t* ESP_EFUSE_CUSTOM_SECURE_VERSION[] = { + &CUSTOM_SECURE_VERSION[0], // Custom secure version + NULL +}; + diff --git a/examples/system/efuse/main/esp_efuse_custom_table.csv b/examples/system/efuse/main/esp_efuse_custom_table.csv new file mode 100644 index 000000000..2f9177154 --- /dev/null +++ b/examples/system/efuse/main/esp_efuse_custom_table.csv @@ -0,0 +1,18 @@ +# field_name, | efuse_block, | bit_start, | bit_count, |comment # +# | (EFUSE_BLK0 | (0..255) | (1..-) | # +# | EFUSE_BLK1 | |MAX_BLK_LEN*| # +# | EFUSE_BLK2 | | | # +# | EFUSE_BLK3) | | | # +########################################################################## +# *) The value MAX_BLK_LEN depends on CONFIG_EFUSE_MAX_BLK_LEN, will be replaced with "None" - 256. "3/4" - 192. "REPEAT" - 128. +# !!!!!!!!!!! # +# After editing this file, run the command manually "make efuse_common_table" or "idf.py efuse_common_table" +# this will generate new source files, next rebuild all the sources. +# !!!!!!!!!!! # + + +MODULE_VERSION, EFUSE_BLK3, 56, 8, Module version +DEVICE_ROLE, EFUSE_BLK3, 64, 3, Device role +SETTING_1, EFUSE_BLK3, 67, 6, Setting 1 +SETTING_2, EFUSE_BLK3, 73, 5, Setting 2 +CUSTOM_SECURE_VERSION, EFUSE_BLK3, 78, 16, Custom secure version diff --git a/examples/system/efuse/main/include/esp_efuse_custom_table.h b/examples/system/efuse/main/include/esp_efuse_custom_table.h new file mode 100644 index 000000000..857ba2d72 --- /dev/null +++ b/examples/system/efuse/main/include/esp_efuse_custom_table.h @@ -0,0 +1,36 @@ +// Copyright 2017-2018 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 + +#ifdef __cplusplus +extern "C" { +#endif + + +// md5_digest_table 584317af6a850ee16ef6206c139d6cf5 +// This file was generated from the file esp_efuse_custom_table.csv. DO NOT CHANGE THIS FILE MANUALLY. +// If you want to change some fields, you need to change esp_efuse_custom_table.csv file +// then run `efuse_common_table` or `efuse_custom_table` command it will generate this file. +// To show efuse_table run the command 'show_efuse_table'. + + +extern const esp_efuse_desc_t* ESP_EFUSE_MODULE_VERSION[]; +extern const esp_efuse_desc_t* ESP_EFUSE_DEVICE_ROLE[]; +extern const esp_efuse_desc_t* ESP_EFUSE_SETTING_1[]; +extern const esp_efuse_desc_t* ESP_EFUSE_SETTING_2[]; +extern const esp_efuse_desc_t* ESP_EFUSE_CUSTOM_SECURE_VERSION[]; + +#ifdef __cplusplus +} +#endif + diff --git a/examples/system/efuse/sdkconfig.defaults b/examples/system/efuse/sdkconfig.defaults new file mode 100644 index 000000000..88ec85884 --- /dev/null +++ b/examples/system/efuse/sdkconfig.defaults @@ -0,0 +1,2 @@ +CONFIG_EFUSE_CUSTOM_TABLE=y +CONFIG_EFUSE_VIRTUAL=y