Mismatch chip id on preencrypted OTA

RuslanPopov
Posts: 21
Joined: Mon Nov 21, 2022 3:47 pm

Mismatch chip id on preencrypted OTA

Postby RuslanPopov » Fri Dec 16, 2022 9:43 am

Hi all.

I am playing with preencrypted OTA on ESP-IDF v4.4.3. I have used https://components.espressif.com/compon ... rypted_img and backported some stuff of esp_https_ota from v5.0.

I did the following:

1. Check that RSA 3072 on the device and in the CICD are the same.
2. Prepare the application (sign, encode for FE, encrypted with RSA, decrypt it back for checking).
3. Store the firmware on S3 (it supports HTTPS) and check that it is downloadable.
4. Send to device a command to start OTA:

I (41003071) esp_https_ota: Starting OTA...
I (41003081) esp_https_ota: Writing to partition subtype 17 at offset 0x190000
I (41003171) esp_encrypted_img: Magic Verified
I (41003191) esp_encrypted_img: Reading RSA private key
E (41007311) esp_https_ota: Mismatch chip id, expected 0, found 3556
E (41007311) OTA: Complete data was not received.
E (41007321) OTA: ESP_HTTPS_OTA upgrade failed

Also, I removed chip id check from OTA and got:

E (114171) esp_ota_ops: OTA image has invalid magic byte (expected 0xE9, saw 0x4a)
E (114171) esp_https_ota: Error: esp_ota_write failed! err=0x1503
D (114171) HTTP_CLIENT: Data processed 1024 != Data specified in content length 741888
E (114181) OTA: Complete data was not received.
E (114191) OTA: ESP_HTTPS_OTA upgrade failed

It seems that there is a RSA decryption problems (i.e. decryption of block is passed ok but there are some problems in data structures).

Is there anyone who uses preencrypted OTA successfully?

schafon
Posts: 5
Joined: Mon Dec 12, 2022 7:48 pm

Re: Mismatch chip id on preencrypted OTA

Postby schafon » Fri Dec 30, 2022 6:53 pm

I'm having a similar problem.
I'm doing firmware OTA with the same code for esp32-s2 and esp32-s3.
The esp-32-s3 works as intended, it downloads the firmware and reboot and everything works.
But for the esp-32-s2 it doesn't work.
gives me esp_https_ota: Mismatch chip id, expected 2, found 25300

I'm using IDF 5 BTW.

The only different I have between the 2 boards is the flash size. the S3 has 8MB of flash while the S2 has 4.
My code is around 0.9mb.
I've increased the partitions size to 1.3mb

I've opened an issue:
https://github.com/espressif/esp-idf/issues/10467

Who is online

Users browsing this forum: No registered users and 352 guests