Chip Revision
Overview
A new chip versioning logic was introduced in new chips. Chips have several eFuse version fields:
- Major wafer version ( - WAFER_VERSION_MAJOReFuse)
- Minor wafer version ( - WAFER_VERSION_MINOReFuse)
- Ignore maximal revision ( - DISABLE_WAFER_VERSION_MAJOReFuse)
The new versioning logic is being introduced to distinguish changes in chips as breaking changes and non-breaking changes. Chips with non-breaking changes can run the same software as the previous chip. The previous chip means that the major version is the same.
If the newly released chip does not have breaking changes, that means it can run the same software as the previous chip, then in that chip we keep the same major version and increment the minor version by 1. Otherwise, if there is a breaking change in the newly released chip, meaning it can not run the same software as the previous chip, then in that chip we increase the major version and set the minor version to 0.
The software supports a number of revisions, from the minimum to the maximum (the min/max configs are defined in Kconfig). If the software is unaware of a new chip (when the chip version is out of range), it will refuse to run on it unless the Ignore maximum revision restrictions bit is set. This bit removes the upper revision limit.
Minimum versions limits the software to only run on a chip revision that is high enough to support some features. Maximum version is the maximum version that is well-supported by current software. When chip version is above the maximum version, software will reject to boot, because it may not work on, or work with risk on the chip.
Adding the major and minor wafer revision make the versioning logic is branchable.
Note
The previous versioning logic was based on a single eFuse version field (WAFER_VERSION). This approach makes it impossible to mark chips as breaking or non-breaking changes, and the versioning logic becomes linear.
Using the branched versioning scheme allows us to support more chips in the software without updating the software when a new released compatible chip is used. Thus, the software will be compatible with as many new chip revisions as possible. If the software is no longer compatible with a new chip with breaking changes, the software will abort.
Revisions
| ECO | Revision (Major.Minor) | 
| ECO0 | v0.0 | 
| ECO1 | v0.1 | 
| ECO2 | v0.2 | 
Chip Revision vX.Y, where:
- Xmeans Major wafer version. If it is changed, it means that the current software version is not compatible with this released chip and the software must be updated to use this chip.
- Ymeans Minor wafer version. If it is changed that means the current software version is compatible with the released chip, and there is no need to update the software.
The vX.Y chip version format will be used further instead of the ECO number.
Representing Revision Requirement Of A Binary Image
The 2nd stage bootloader and the application binary images have the esp_image_header_t header, which stores the revision numbers of the chip on which the software can be run. This header has 3 fields related to revisions:
- min_chip_rev- Minimal chip MAJOR revision required by image (but for ESP32-C3 it is MINOR revision). Its value is determined by CONFIG_ESP32H2_REV_MIN.
- min_chip_rev_full- Minimal chip MINOR revision required by image in format:- major * 100 + minor. Its value is determined by CONFIG_ESP32H2_REV_MIN.
- max_chip_rev_full- Maximal chip revision required by image in format:- major * 100 + minor. Its value is determined by- CONFIG_ESP32H2_REV_MAX_FULL. It can not be changed by user. Only Espressif can change it when a new version will be supported in IDF.
Chip Revision APIs
These APIs helps to get chip revision from eFuses:
- efuse_hal_chip_revision(). It returns revision in the- major * 100 + minorformat.
- efuse_hal_get_major_chip_version(). It returns Major revision.
- efuse_hal_get_minor_chip_version(). It returns Minor revision.
The following Kconfig definitions (in major * 100 + minor format) that can help add the chip revision dependency to the code:
- CONFIG_ESP32H2_REV_MIN_FULL
- CONFIG_ESP_REV_MIN_FULL
- CONFIG_ESP32H2_REV_MAX_FULL
- CONFIG_ESP_REV_MAX_FULL
Maximal And Minimal Revision Restrictions
The order for checking the minimum and maximum revisions:
- The 1st stage bootloader (ROM bootloader) does not check minimal and maximal revision fields from - esp_image_header_tbefore running the 2nd stage bootloader.
- The 2nd stage bootloader checks at the initialization phase that bootloader itself can be launched on the chip of this revision. It extracts the minimum revision from the header of the bootloader image and checks against the chip revision from eFuses. If the chip revision is less than the minimum revision, the bootloader refuses to boot up and aborts. The maximum revision is not checked at this phase. 
- Then the 2nd stage bootloader checks the revision requirements of the application. It extracts the minimum and maximum revisions from the header of the application image and checks against the chip revision from eFuses. If the chip revision is less than the minimum revision or higher than the maximum revision, the bootloader refuses to boot up and aborts. However, if the Ignore maximal revision bit is set, the maximum revision constraint can be ignored. The ignore bit is set by the customer themself when there is confirmation that the software is able to work with this chip revision. 
- Further, at the OTA update stage, the running application checks if the new software matches the chip revision. It extracts the minimum and maximum revisions from the header of the new application image and checks against the chip revision from eFuses. It checks for revision matching in the same way that the bootloader does, so that the chip revision is between the min and max revisions (logic of ignoring max revision also applies). 
Issues
- If the 2nd stage bootloader is run on the chip revision < minimum revision shown in the image, a reboot occurs. The following message will be printed: 
Image requires chip rev >= v3.0, but chip is v1.0
To resolve this issue:
- make sure the chip you are using is suitable for the software, or use a chip with the required minimum revision or higher. 
- update the software with CONFIG_ESP32H2_REV_MIN to get it - <=the revision of chip being used
- If application does not match minimal and maximal chip revisions, a reboot occurs. The following message will be printed: 
Image requires chip rev <= v2.99, but chip is v3.0
To resolve this issue, update the IDF to a newer version that supports the used chip (CONFIG_ESP32H2_REV_MAX_FULL). Another way to fix this is to set the Ignore maximal revision bit in eFuse or use a chip that is suitable for the software.
Backward Compatible With Bootloaders Built By Older ESP-IDF Versions
Please check the chip version using esptool chip_id command.
API Reference
Header File
Functions
- 
void efuse_hal_get_mac(uint8_t *mac)
- get factory mac address 
- 
uint32_t efuse_hal_chip_revision(void)
- Returns chip version. - Returns
- Chip version in format: Major * 100 + Minor 
 
- 
uint32_t efuse_hal_blk_version(void)
- Return block version. - Returns
- Block version in format: Major * 100 + Minor 
 
- 
bool efuse_hal_flash_encryption_enabled(void)
- Is flash encryption currently enabled in hardware? - Flash encryption is enabled if the FLASH_CRYPT_CNT efuse has an odd number of bits set. - Returns
- true if flash encryption is enabled. 
 
- 
uint32_t efuse_hal_get_major_chip_version(void)
- Returns major chip version. 
- 
uint32_t efuse_hal_get_minor_chip_version(void)
- Returns minor chip version. 
- 
void efuse_hal_set_ecdsa_key(int efuse_key_blk)
- Set the efuse block that should be used as ECDSA private key. - Note - The efuse block must be burnt with key purpose ECDSA_KEY - Parameters
- efuse_key_blk -- Efuse key block number (Must be in [EFUSE_BLK_KEY0...EFUSE_BLK_KEY_MAX - 1] range)