Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow bypassing ASN.1 processing of public key for ED25519 #2089

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

de-nordic
Copy link
Collaborator

@de-nordic de-nordic commented Oct 8, 2024

Add conditional compilation of ASN.1 decoding of ED25519 key.

This allows to cut out the ASN.1 encoding, which results in reduced flash size.

Comparison on nrf52840dk/nrf52840 build of MCUboot with the ED25519 enabled

west build -p -d builds/nrf52_mcuboot_ed25519_no_asn -b nrf52840dk/nrf52840 bootloader/mcuboot/boot/zephyr/ -DCONFIG_BOOT_SIGNATURE_TYPE_ED25519=y

Reduces code from 40422 bytes to 39918 bytes, when -DCONFIG_BOOT_KEY_IMPORT_BYPASS_ASN=y is added.

Another benefit of the option is that it is no longer needed to have portion of the mbedTLS, that does the ASN.1 support, enabled when compiling MCUboot with ED25519 for TinyCrypt.

de-nordic added a commit to de-nordic/sdk-mcuboot that referenced this pull request Oct 8, 2024
…ey import

The commit adds MCUBOOT_KEY_IMPORT_BYPASS_ASN configuration option
that allows bypassing ASN.1 decoding of ED25519 public key, compiled
into MCUboot.
When the option is enabled the key will be accessed directly
and ASN.1 processing is not compiled in, resulting in smaller
footprint of MCUboot, at a cost of reduced detection of invalid
key, i.e. public key designated for different method than
compiled in.

Upstream PR: mcu-tools/mcuboot#2089

Signed-off-by: Dominik Ermel <[email protected]>
de-nordic added a commit to de-nordic/sdk-mcuboot that referenced this pull request Oct 8, 2024
…SS_ASN

The option enables MCUboot configuration option
MCUBOOT_KEY_IMPORT_BYPASS_ASN.

Upstream PR: mcu-tools/mcuboot#2089

Signed-off-by: Dominik Ermel <[email protected]>
@de-nordic de-nordic requested a review from nordicjm October 9, 2024 09:17
boot/zephyr/Kconfig Outdated Show resolved Hide resolved
@nordicjm nordicjm changed the title Allowi bypassing ASN.1 processing of public key for ED25519 Allow bypassing ASN.1 processing of public key for ED25519 Oct 9, 2024
@de-nordic de-nordic force-pushed the ed25519-asn1-bypass branch from 1cdb478 to 86e26fa Compare October 9, 2024 12:01
de-nordic added a commit to de-nordic/sdk-mcuboot that referenced this pull request Oct 9, 2024
…ey import

The commit adds MCUBOOT_KEY_IMPORT_BYPASS_ASN configuration option
that allows bypassing ASN.1 decoding of ED25519 public key, compiled
into MCUboot.
When the option is enabled the key will be accessed directly
and ASN.1 processing is not compiled in, resulting in smaller
footprint of MCUboot, at a cost of reduced detection of invalid
key, i.e. public key designated for different method than
compiled in.

Upstream PR: mcu-tools/mcuboot#2089

Signed-off-by: Dominik Ermel <[email protected]>
de-nordic added a commit to de-nordic/sdk-mcuboot that referenced this pull request Oct 9, 2024
…SS_ASN

The option enables MCUboot configuration option
MCUBOOT_KEY_IMPORT_BYPASS_ASN.

Upstream PR: mcu-tools/mcuboot#2089

Signed-off-by: Dominik Ermel <[email protected]>
@nordicjm nordicjm requested a review from d3zd3z October 10, 2024 07:48
@de-nordic
Copy link
Collaborator Author

@d3zd3z hej, got time to review?

@davidvincze davidvincze self-requested a review January 14, 2025 14:10
@davidvincze
Copy link
Collaborator

davidvincze commented Jan 14, 2025

It looks good to me, I only have:

  • Comment: #include "mbedtls/oid.h" and #include "mbedtls/asn1.h" could be conditional includes if ASN.1 is bypassed.

  • Note: at https://github.com/mcu-tools/mcuboot/blob/main/boot/bootutil/include/bootutil/crypto/ecdsa.h#L427 it does some manual parsing and checks the type of the key and curve. We could move it to a common ecdsa_helper file for example if needed, but bypassing ASN.1 moves us towards the usage of raw keys and signatures (instead of ASN.1) which has already been mentioned/suggested (considering the fact that currently MCUboot configuration clearly determines the expected signature and key type).

@de-nordic
Copy link
Collaborator Author

It looks good to me, I only have:

* Comment:  #include "mbedtls/oid.h" and #include "mbedtls/asn1.h" could be conditional includes if ASN.1 is bypassed.

* Note: at https://github.com/mcu-tools/mcuboot/blob/main/boot/bootutil/include/bootutil/crypto/ecdsa.h#L427 it does some manual parsing and checks the type of the key and curve. We could move it to a common ecdsa_helper file for example if needed, but bypassing ASN.1 moves us towards the usage of raw keys and signatures (instead of ASN.1) which has already been mentioned/suggested (considering the fact that currently MCUboot configuration clearly determines the expected signature and key type).

I will implement the changes.

@davidvincze
Copy link
Collaborator

As I already mentioned, the parsing of ECDSA is handled differently in the existing code, but I think your solution is also reliable as the variability in size is only present for the signatures (encoding unsigned values as signed integers). The key is encoded as a bit string with 2 extra bytes (num of unused bits and compression) and its size is deterministic.

@de-nordic de-nordic force-pushed the ed25519-asn1-bypass branch from 86e26fa to e27d7fa Compare January 22, 2025 17:29
@de-nordic
Copy link
Collaborator Author

As I already mentioned, the parsing of ECDSA is handled differently in the existing code, but I think your solution is also reliable as the variability in size is only present for the signatures (encoding unsigned values as signed integers). The key is encoded as a bit string with 2 extra bytes (num of unused bits and compression) and its size is deterministic.

I have applied the comment regarding ifdefing includes.
I will try to do the edcsa, once I figure out the bootutil_read_bigint.

The commit adds MCUBOOT_KEY_IMPORT_BYPASS_ASN configuration option
that allows bypassing ASN.1 decoding of ED25519 public key, compiled
into MCUboot.
When the option is enabled the key will be accessed directly
and ASN.1 processing is not compiled in, resulting in smaller
footprint of MCUboot, at a cost of reduced detection of invalid
key, i.e. public key designated for different method than
compiled in.

Signed-off-by: Dominik Ermel <[email protected]>
The option enables MCUboot configuration option
MCUBOOT_KEY_IMPORT_BYPASS_ASN.

Signed-off-by: Dominik Ermel <[email protected]>
@de-nordic de-nordic force-pushed the ed25519-asn1-bypass branch from e27d7fa to 1da4a11 Compare January 23, 2025 16:42
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
crypto Encryption support
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants