eFuse Manager¶
Introduction¶
The eFuse Manager library is designed to structure access to eFuse bits and make using these easy. This library operates eFuse bits by a structure name wich assigned in eFuse table. This sections introduces some concepts used by eFuse Manager.
Hardware description¶
The ESP32 has a number of eFuses which can store system and user parameters. Each eFuse is a one-bit field which can be programmed to 1 after which it cannot be reverted back to 0. Some of system parameters are using these eFuse bits directly by hardware modules and have special place (for example EFUSE_BLK0). For more details see ESP32 Technical Reference Manual in part 20 eFuse controller. Some eFuse bits are available for user applications.
ESP32 has 4 eFuse blocks each of the size of 256 bits (not all bits are available):
- EFUSE_BLK0 is used entirely for system purposes;
- EFUSE_BLK1 is used for flash encrypt key. If not using that Flash Encryption feature, they can be used for another purpose;
- EFUSE_BLK2 is used for security boot key. If not using that Secure Boot feature, they can be used for another purpose;
- EFUSE_BLK3 can be partially reserved for the custom MAC address, or used entirely for user application. Note that some bits are already used in IDF.
Each block is divided into 8 32-bits registers.
eFuse Manager component¶
The component has API functions for reading and writing fields. Access to the fields is carried out through the structures that describe the location of the eFuse bits in the blocks. The component provides the ability to form fields of any length and from any number of individual bits. The description of the fields is made in a CSV file in a table form. To generate from a tabular form (CSV file) in the C-source uses the tool efuse_table_gen.py. The tool checks the CSV file for uniqueness of field names and bit intersection, in case of using a custom file from the user’s project directory, the utility will check with the common CSV file.
CSV files:
- common (esp_efuse_table.csv) - contains eFuse fields which are used inside the IDF. C-source generation should be done manually when changing this file (run command ‘make efuse_common_table’ or idf.py efuse_common_table). Note that changes in this file can lead to incorrect operation.
- custom - (optional and can be enabled by
CONFIG_EFUSE_CUSTOM_TABLE
) contains eFuse fields that are used by the user in their application. C-source generation should be done manually when changing this file (run command ‘make efuse_custom_table’ or idf.py efuse_custom_table).
Description CSV file¶
The CSV file contains a description of the eFuse fields. In the simple case, one field has one line of description. Table header:
# field_name, efuse_block(EFUSE_BLK0..EFUSE_BLK3), bit_start(0..255), bit_count(1..256), comment
Individual params in CSV file the following meanings:
- field_name
- Name of field. The prefix ESP_EFUSE_ will be added to the name, and this field name will be available in the code. This name will be used to access the fields. The name must be unique for all fields. If the line has an empty name, then this line is combined with the previous field. This allows you to set an arbitrary order of bits in the field, and expand the field as well (see
MAC_FACTORY
field in the common table). - efuse_block
- Block number. It determines where the eFuse bits will be placed for this field. Available EFUSE_BLK0..EFUSE_BLK3.
- bit_start
- Start bit number (0..255). The bit_start field can be omitted. In this case, it will be set to bit_start + bit_count from the previous record, if it has the same efuse_block. Otherwise (if efuse_block is different, or this is the first entry), an error will be generated.
- bit_count
- The number of bits to use in this field (1..-). This parameter can not be omitted. This field also may be
MAX_BLK_LEN
in this case, the field length will have the maximum block length, taking into account the coding scheme (applicable forESP_EFUSE_SECURE_BOOT_KEY
andESP_EFUSE_ENCRYPT_FLASH_KEY
fields). The valueMAX_BLK_LEN
depends onCONFIG_EFUSE_MAX_BLK_LEN
, will be replaced with “None” - 256, “3/4” - 192, “REPEAT” - 128. - comment
- This param is using for comment field, it also move to C-header file. The comment field can be omitted.
If a non-sequential bit order is required to describe a field, then the field description in the following lines should be continued without specifying a name, this will indicate that it belongs to one field. For example two fields MAC_FACTORY and MAC_FACTORY_CRC:
# Factory MAC address #
#######################
MAC_FACTORY, EFUSE_BLK0, 72, 8, Factory MAC addr [0]
, EFUSE_BLK0, 64, 8, Factory MAC addr [1]
, EFUSE_BLK0, 56, 8, Factory MAC addr [2]
, EFUSE_BLK0, 48, 8, Factory MAC addr [3]
, EFUSE_BLK0, 40, 8, Factory MAC addr [4]
, EFUSE_BLK0, 32, 8, Factory MAC addr [5]
MAC_FACTORY_CRC, EFUSE_BLK0, 80, 8, CRC8 for factory MAC address
This field will available in code as ESP_EFUSE_MAC_FACTORY and ESP_EFUSE_MAC_FACTORY_CRC.
efuse_table_gen.py tool¶
The tool is designed to generate C-source files from CSV file and validate fields. First of all, the check is carried out on the uniqueness of the names and overlaps of the field bits. If an additional custom file is used, it will be checked with the existing common file (esp_efuse_table.csv). In case of errors, a message will be displayed and the string that caused the error. C-source files contain structures of type esp_efuse_desc_t.
To generate a common files, use the following command ‘make efuse_common_table’ or idf.py efuse_common_table or:
cd $IDF_PATH/components/efuse/
./efuse_table_gen.py esp32/esp_efuse_table.csv
After generation in the folder esp32 create:
- esp_efuse_table.c file.
- In include folder esp_efuse_table.c file.
To generate a custom files, use the following command ‘make efuse_custom_table’ or idf.py efuse_custom_table or:
cd $IDF_PATH/components/efuse/
./efuse_table_gen.py esp32/esp_efuse_table.csv PROJECT_PATH/main/esp_efuse_custom_table.csv
After generation in the folder PROJECT_PATH/main create:
- esp_efuse_custom_table.c file.
- In include folder esp_efuse_custom_table.c file.
To use the generated fields, you need to include two files:
#include "esp_efuse.h"
#include "esp_efuse_table.h" or "esp_efuse_custom_table.h"
Support coding scheme¶
eFuse have three coding schemes:
None
(value 0).3/4
(value 1).Repeat
(value 2).
The coding scheme affects only EFUSE_BLK1, EFUSE_BLK2 and EFUSE_BLK3 blocks. EUSE_BLK0 block always has a coding scheme None
.
Coding changes the number of bits that can be written into a block, the block length is constant 256, some of these bits are used for encoding and are not used.
When using a coding scheme, the length of the payload that can be written is limited (for more details 20.3.1.3 System Parameter coding_scheme
):
- None 256 bits.
- 3/4 192 bits.
- Repeat 128 bits.
You can find out the coding scheme of your chip:
- run a
espefuse.py -p COM4 summary
command. - from
esptool
utility logs (during flashing). - calling the function in the code
esp_efuse_get_coding_scheme()
for the EFUSE_BLK3 block.
eFuse tables must always comply with the coding scheme in the chip. There is an EFUSE_CODE_SCHEME_SELECTOR
option to select the coding type for tables in a Kconfig. When generating source files, if your tables do not follow the coding scheme, an error message will be displayed. Adjust the length or offset fields.
If your program was compiled with None
encoding and 3/4
is used in the chip, then the ESP_ERR_CODING
error may occur when calling the eFuse API (the field is outside the block boundaries). If the field matches the new block boundaries, then the API will work without errors.
Also, 3/4 coding scheme imposes restrictions on writing bits belonging to one coding unit. The whole block with a length of 256 bits is divided into 4 coding units, and in each coding unit there are 6 bytes of useful data and 2 service bytes. These 2 service bytes contain the checksum of the previous 6 data bytes.
It turns out that only one field can be written into one coding unit. Repeated rewriting in one coding unit is prohibited. But if the record was made in advance or through a esp_efuse_write_block()
function, then reading the fields belonging to one coding unit is possible.
After changing the coding scheme, run efuse_common_table
and efuse_custom_table
commands to check the tables of the new coding scheme.
eFuse API¶
Access to the fields is via a pointer to the description structure. API functions have some basic operation:
esp_efuse_read_field_blob()
- returns an array of read eFuse bits.esp_efuse_read_field_cnt()
- returns the number of bits programmed as “1”.esp_efuse_write_field_blob()
- writes an array.esp_efuse_write_field_cnt()
- writes a required count of bits as “1”.esp_efuse_get_field_size()
- returns the number of bits by the field name.esp_efuse_read_reg()
- returns value of eFuse register.esp_efuse_write_reg()
- writes value to eFuse register.esp_efuse_get_coding_scheme()
- returns eFuse coding scheme for blocks.esp_efuse_read_block()
- reads key to eFuse block starting at the offset and the required size.esp_efuse_write_block()
- writes key to eFuse block starting at the offset and the required size.
For frequently used fields, special functions are made, like this esp_efuse_get_chip_ver()
, esp_efuse_get_pkg_ver()
.
How add a new field¶
- Find a free bits for field. Show esp_efuse_table.csv file or run
make show_efuse_table
oridf.py show_efuse_table
or the next command:
$ ./efuse_table_gen.py esp32/esp_efuse_table.csv --info
eFuse coding scheme: NONE
# field_name efuse_block bit_start bit_count
1 WR_DIS_FLASH_CRYPT_CNT EFUSE_BLK0 2 1
2 WR_DIS_BLK1 EFUSE_BLK0 7 1
3 WR_DIS_BLK2 EFUSE_BLK0 8 1
4 WR_DIS_BLK3 EFUSE_BLK0 9 1
5 RD_DIS_BLK1 EFUSE_BLK0 16 1
6 RD_DIS_BLK2 EFUSE_BLK0 17 1
7 RD_DIS_BLK3 EFUSE_BLK0 18 1
8 FLASH_CRYPT_CNT EFUSE_BLK0 20 7
9 MAC_FACTORY EFUSE_BLK0 32 8
10 MAC_FACTORY EFUSE_BLK0 40 8
11 MAC_FACTORY EFUSE_BLK0 48 8
12 MAC_FACTORY EFUSE_BLK0 56 8
13 MAC_FACTORY EFUSE_BLK0 64 8
14 MAC_FACTORY EFUSE_BLK0 72 8
15 MAC_FACTORY_CRC EFUSE_BLK0 80 8
16 CHIP_VER_DIS_APP_CPU EFUSE_BLK0 96 1
17 CHIP_VER_DIS_BT EFUSE_BLK0 97 1
18 CHIP_VER_PKG EFUSE_BLK0 105 3
19 CHIP_CPU_FREQ_LOW EFUSE_BLK0 108 1
20 CHIP_CPU_FREQ_RATED EFUSE_BLK0 109 1
21 CHIP_VER_REV1 EFUSE_BLK0 111 1
22 ADC_VREF_AND_SDIO_DREF EFUSE_BLK0 136 6
23 XPD_SDIO_REG EFUSE_BLK0 142 1
24 SDIO_TIEH EFUSE_BLK0 143 1
25 SDIO_FORCE EFUSE_BLK0 144 1
26 ENCRYPT_CONFIG EFUSE_BLK0 188 4
27 CONSOLE_DEBUG_DISABLE EFUSE_BLK0 194 1
28 ABS_DONE_0 EFUSE_BLK0 196 1
29 DISABLE_JTAG EFUSE_BLK0 198 1
30 DISABLE_DL_ENCRYPT EFUSE_BLK0 199 1
31 DISABLE_DL_DECRYPT EFUSE_BLK0 200 1
32 DISABLE_DL_CACHE EFUSE_BLK0 201 1
33 ENCRYPT_FLASH_KEY EFUSE_BLK1 0 256
34 SECURE_BOOT_KEY EFUSE_BLK2 0 256
35 MAC_CUSTOM_CRC EFUSE_BLK3 0 8
36 MAC_CUSTOM EFUSE_BLK3 8 48
37 ADC1_TP_LOW EFUSE_BLK3 96 7
38 ADC1_TP_HIGH EFUSE_BLK3 103 9
39 ADC2_TP_LOW EFUSE_BLK3 112 7
40 ADC2_TP_HIGH EFUSE_BLK3 119 9
41 SECURE_VERSION EFUSE_BLK3 128 32
42 MAC_CUSTOM_VER EFUSE_BLK3 184 8
Used bits in eFuse table:
EFUSE_BLK0
[2 2] [7 9] [16 18] [20 27] [32 87] [96 97] [105 109] [111 111] [136 144] [188 191] [194 194] [196 196] [198 201]
EFUSE_BLK1
[0 255]
EFUSE_BLK2
[0 255]
EFUSE_BLK3
[0 55] [96 159] [184 191]
Note: Not printed ranges are free for using. (bits in EFUSE_BLK0 are reserved for Espressif)
Parsing eFuse CSV input file $IDF_PATH/components/efuse/esp32/esp_efuse_table.csv ...
Verifying eFuse table...
The number of bits not included in square brackets is free (bits in EFUSE_BLK0 are reserved for Espressif). All fields are checked for overlapping.
- Fill a line for field: field_name, efuse_block, bit_start, bit_count, comment.
- Run a
show_efuse_table
command to check eFuse table. To generate source files runefuse_common_table
orefuse_custom_table
command.
Debug eFuse & Unit tests¶
Virtual eFuses¶
The Kconfig option CONFIG_EFUSE_VIRTUAL
will virtualize eFuse values inside the eFuse Manager, so writes are emulated and no eFuse values are permanently changed. This can be useful for debugging app and unit tests.
espefuse.py¶
esptool includes a useful tool for reading/writing ESP32 eFuse bits - espefuse.py.
espefuse.py -p COM4 summary
espefuse.py v2.3.1
Connecting........_
Security fuses:
FLASH_CRYPT_CNT Flash encryption mode counter = 0 R/W (0x0)
FLASH_CRYPT_CONFIG Flash encryption config (key tweak bits) = 0 R/W (0x0)
CONSOLE_DEBUG_DISABLE Disable ROM BASIC interpreter fallback = 1 R/W (0x1)
ABS_DONE_0 secure boot enabled for bootloader = 0 R/W (0x0)
ABS_DONE_1 secure boot abstract 1 locked = 0 R/W (0x0)
JTAG_DISABLE Disable JTAG = 0 R/W (0x0)
DISABLE_DL_ENCRYPT Disable flash encryption in UART bootloader = 0 R/W (0x0)
DISABLE_DL_DECRYPT Disable flash decryption in UART bootloader = 0 R/W (0x0)
DISABLE_DL_CACHE Disable flash cache in UART bootloader = 0 R/W (0x0)
BLK1 Flash encryption key
= 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 R/W
BLK2 Secure boot key
= 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 R/W
BLK3 Variable Block 3
= 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 fa 87 02 91 00 00 00 00 00 00 00 00 00 00 00 00 R/W
Efuse fuses:
WR_DIS Efuse write disable mask = 0 R/W (0x0)
RD_DIS Efuse read disablemask = 0 R/W (0x0)
CODING_SCHEME Efuse variable block length scheme = 1 R/W (0x1) (3/4)
KEY_STATUS Usage of efuse block 3 (reserved) = 0 R/W (0x0)
Config fuses:
XPD_SDIO_FORCE Ignore MTDI pin (GPIO12) for VDD_SDIO on reset = 0 R/W (0x0)
XPD_SDIO_REG If XPD_SDIO_FORCE, enable VDD_SDIO reg on reset = 0 R/W (0x0)
XPD_SDIO_TIEH If XPD_SDIO_FORCE & XPD_SDIO_REG, 1=3.3V 0=1.8V = 0 R/W (0x0)
SPI_PAD_CONFIG_CLK Override SD_CLK pad (GPIO6/SPICLK) = 0 R/W (0x0)
SPI_PAD_CONFIG_Q Override SD_DATA_0 pad (GPIO7/SPIQ) = 0 R/W (0x0)
SPI_PAD_CONFIG_D Override SD_DATA_1 pad (GPIO8/SPID) = 0 R/W (0x0)
SPI_PAD_CONFIG_HD Override SD_DATA_2 pad (GPIO9/SPIHD) = 0 R/W (0x0)
SPI_PAD_CONFIG_CS0 Override SD_CMD pad (GPIO11/SPICS0) = 0 R/W (0x0)
DISABLE_SDIO_HOST Disable SDIO host = 0 R/W (0x0)
Identity fuses:
MAC MAC Address
= 84:0d:8e:18:8e:44 (CRC ad OK) R/W
CHIP_VER_REV1 Silicon Revision 1 = 1 R/W (0x1)
CHIP_VERSION Reserved for future chip versions = 2 R/W (0x2)
CHIP_PACKAGE Chip package identifier = 0 R/W (0x0)
Calibration fuses:
BLK3_PART_RESERVE BLOCK3 partially served for ADC calibration data = 1 R/W (0x1)
ADC_VREF Voltage reference calibration = 1114 R/W (0x2)
ADC1_TP_LOW ADC1 150mV reading = 346 R/W (0x11)
ADC1_TP_HIGH ADC1 850mV reading = 3285 R/W (0x5)
ADC2_TP_LOW ADC2 150mV reading = 449 R/W (0x7)
ADC2_TP_HIGH ADC2 850mV reading = 3362 R/W (0x1f5)
Flash voltage (VDD_SDIO) determined by GPIO12 on reset (High for 1.8V, Low/NC for 3.3V).
To get a dump for all eFuse registers.
espefuse.py -p COM4 dump
$ espefuse.py -p COM4 dump
espefuse.py v2.3.1
Connecting........__
EFUSE block 0:
00000000 c403bb68 0082240a 00000000 00000035 00000000 00000000
EFUSE block 1:
00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000
EFUSE block 2:
00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000
EFUSE block 3:
00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000
Header File¶
Functions¶
-
esp_err_t
esp_efuse_read_field_blob
(const esp_efuse_desc_t *field[], void *dst, size_t dst_size_bits)¶ Reads bits from EFUSE field and writes it into an array.
The number of read bits will be limited to the minimum value from the description of the bits in “field” structure or “dst_size_bits” required size. Use “esp_efuse_get_field_size()” function to determine the length of the field.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- Parameters
field
: A pointer to the structure describing the fields of efuse.dst
: A pointer to array that will contain the result of reading.dst_size_bits
: The number of bits required to read. If the requested number of bits is greater than the field, the number will be limited to the field size.
-
esp_err_t
esp_efuse_read_field_cnt
(const esp_efuse_desc_t *field[], size_t *out_cnt)¶ Reads bits from EFUSE field and returns number of bits programmed as “1”.
If the bits are set not sequentially, they will still be counted.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- Parameters
field
: A pointer to the structure describing the fields of efuse.out_cnt
: A pointer that will contain the number of programmed as “1” bits.
-
esp_err_t
esp_efuse_write_field_blob
(const esp_efuse_desc_t *field[], const void *src, size_t src_size_bits)¶ Writes array to EFUSE field.
The number of write bits will be limited to the minimum value from the description of the bits in “field” structure or “src_size_bits” required size. Use “esp_efuse_get_field_size()” function to determine the length of the field. After the function is completed, the writing registers are cleared.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- ESP_ERR_EFUSE_REPEATED_PROG: Error repeated programming of programmed bits is strictly forbidden.
- ESP_ERR_CODING: Error range of data does not match the coding scheme.
- Parameters
field
: A pointer to the structure describing the fields of efuse.src
: A pointer to array that contains the data for writing.src_size_bits
: The number of bits required to write.
-
esp_err_t
esp_efuse_write_field_cnt
(const esp_efuse_desc_t *field[], size_t cnt)¶ Writes a required count of bits as “1” to EFUSE field.
If there are no free bits in the field to set the required number of bits to “1”, ESP_ERR_EFUSE_CNT_IS_FULL error is returned, the field will not be partially recorded. After the function is completed, the writing registers are cleared.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- ESP_ERR_EFUSE_CNT_IS_FULL: Not all requested cnt bits is set.
- Parameters
field
: A pointer to the structure describing the fields of efuse.cnt
: Required number of programmed as “1” bits.
-
esp_err_t
esp_efuse_set_write_protect
(esp_efuse_block_t blk)¶ Sets a write protection for the whole block.
After that, it is impossible to write to this block. The write protection does not apply to block 0.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- ESP_ERR_EFUSE_CNT_IS_FULL: Not all requested cnt bits is set.
- ESP_ERR_NOT_SUPPORTED: The block does not support this command.
- Parameters
blk
: Block number of eFuse. (EFUSE_BLK1, EFUSE_BLK2 and EFUSE_BLK3)
-
esp_err_t
esp_efuse_set_read_protect
(esp_efuse_block_t blk)¶ Sets a read protection for the whole block.
After that, it is impossible to read from this block. The read protection does not apply to block 0.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- ESP_ERR_EFUSE_CNT_IS_FULL: Not all requested cnt bits is set.
- ESP_ERR_NOT_SUPPORTED: The block does not support this command.
- Parameters
blk
: Block number of eFuse. (EFUSE_BLK1, EFUSE_BLK2 and EFUSE_BLK3)
-
int
esp_efuse_get_field_size
(const esp_efuse_desc_t *field[])¶ Returns the number of bits used by field.
- Return
- Returns the number of bits used by field.
- Parameters
field
: A pointer to the structure describing the fields of efuse.
-
uint32_t
esp_efuse_read_reg
(esp_efuse_block_t blk, unsigned int num_reg)¶ Returns value of efuse register.
This is a thread-safe implementation. Example: EFUSE_BLK2_RDATA3_REG where (blk=2, num_reg=3)
- Return
- Value of register
- Parameters
blk
: Block number of eFuse.num_reg
: The register number in the block.
-
esp_err_t
esp_efuse_write_reg
(esp_efuse_block_t blk, unsigned int num_reg, uint32_t val)¶ Write value to efuse register.
Apply a coding scheme if necessary. This is a thread-safe implementation. Example: EFUSE_BLK3_WDATA0_REG where (blk=3, num_reg=0)
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_EFUSE_REPEATED_PROG: Error repeated programming of programmed bits is strictly forbidden.
- Parameters
blk
: Block number of eFuse.num_reg
: The register number in the block.val
: Value to write.
-
esp_efuse_coding_scheme_t
esp_efuse_get_coding_scheme
(esp_efuse_block_t blk)¶ Return efuse coding scheme for blocks.
Note: The coding scheme is applicable only to 1, 2 and 3 blocks. For 0 block, the coding scheme is always
NONE
.- Return
- Return efuse coding scheme for blocks
- Parameters
blk
: Block number of eFuse.
-
esp_err_t
esp_efuse_read_block
(esp_efuse_block_t blk, void *dst_key, size_t offset_in_bits, size_t size_bits)¶ Read key to efuse block starting at the offset and the required size.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- ESP_ERR_CODING: Error range of data does not match the coding scheme.
- Parameters
blk
: Block number of eFuse.dst_key
: A pointer to array that will contain the result of reading.offset_in_bits
: Start bit in block.size_bits
: The number of bits required to read.
-
esp_err_t
esp_efuse_write_block
(esp_efuse_block_t blk, const void *src_key, size_t offset_in_bits, size_t size_bits)¶ Write key to efuse block starting at the offset and the required size.
- Return
- ESP_OK: The operation was successfully completed.
- ESP_ERR_INVALID_ARG: Error in the passed arguments.
- ESP_ERR_CODING: Error range of data does not match the coding scheme.
- ESP_ERR_EFUSE_REPEATED_PROG: Error repeated programming of programmed bits
- Parameters
blk
: Block number of eFuse.src_key
: A pointer to array that contains the key for writing.offset_in_bits
: Start bit in block.size_bits
: The number of bits required to write.
-
uint8_t
esp_efuse_get_chip_ver
(void)¶ Returns chip version from efuse.
- Return
- chip version
-
uint32_t
esp_efuse_get_pkg_ver
(void)¶ Returns chip package from efuse.
- Return
- chip package
-
void
esp_efuse_burn_new_values
(void)¶
-
void
esp_efuse_reset
(void)¶
-
void
esp_efuse_disable_basic_rom_console
(void)¶
-
esp_err_t
esp_efuse_apply_34_encoding
(const uint8_t *in_bytes, uint32_t *out_words, size_t in_bytes_len)¶
-
void
esp_efuse_write_random_key
(uint32_t blk_wdata0_reg)¶
-
uint32_t
esp_efuse_read_secure_version
()¶
-
bool
esp_efuse_check_secure_version
(uint32_t secure_version)¶
-
void
esp_efuse_init
(uint32_t offset, uint32_t size)¶
Structures¶
-
struct
esp_efuse_desc_t
¶ Structure eFuse field.
Public Members
-
esp_efuse_block_t
efuse_block
¶ Block of eFuse
-
uint8_t
bit_start
¶ Start bit [0..255]
-
uint16_t
bit_count
¶ Length of bit field [1..-]
-
esp_efuse_block_t
Macros¶
-
ESP_ERR_EFUSE
¶ Base error code for efuse api.
-
ESP_OK_EFUSE_CNT
¶ OK the required number of bits is set.
-
ESP_ERR_EFUSE_CNT_IS_FULL
¶ Error field is full.
-
ESP_ERR_EFUSE_REPEATED_PROG
¶ Error repeated programming of programmed bits is strictly forbidden.
-
ESP_ERR_CODING
¶ Error while a encoding operation.
Enumerations¶
-
enum
esp_efuse_block_t
¶ Type of eFuse blocks.
Values:
-
EFUSE_BLK0
= 0¶ Number of eFuse block. Reserved.
-
EFUSE_BLK1
= 1¶ Number of eFuse block. Used for Flash Encryption. If not using that Flash Encryption feature, they can be used for another purpose.
-
EFUSE_BLK2
= 2¶ Number of eFuse block. Used for Secure Boot. If not using that Secure Boot feature, they can be used for another purpose.
-
EFUSE_BLK3
= 3¶ Number of eFuse block. Uses for the purpose of the user.
-