Internet-Draft | Encrypted Payloads in SUIT Manifests | September 2023 |
Tschofenig, et al. | Expires 8 March 2024 | [Page] |
This document specifies techniques for encrypting software, firmware, machine learning models, and personalization data by utilizing the IETF SUIT manifest. Key agreement is provided by ephemeral-static (ES) Diffie-Hellman (DH) and AES Key Wrap (AES-KW). ES-DH uses public key cryptography while AES-KW uses a pre-shared key. Encryption of the plaintext is accomplished with conventional symmetric key cryptography.¶
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.¶
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.¶
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."¶
This Internet-Draft will expire on 8 March 2024.¶
Copyright (c) 2023 IETF Trust and the persons identified as the document authors. All rights reserved.¶
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.¶
Vulnerabilities with Internet of Things (IoT) devices have raised the need for a reliable and secure firmware update mechanism that is also suitable for constrained devices. To protect firmware images, the SUIT manifest format was developed [I-D.ietf-suit-manifest]. It provides a bundle of metadata, including where to find the payload, the devices to which it applies and a security wrapper.¶
[RFC9124] details the information that has to be provided by the SUIT manifest format. In addition to offering protection against modification, via a digital signature or a message authentication code, confidentiality may also be afforded.¶
Encryption prevents third parties, including attackers, from gaining access to the payload. Attackers typically need intimate knowledge of a binary, such as a firmware image, to mount their attacks. For example, return-oriented programming (ROP) [ROP] requires access to the binary and encryption makes it much more difficult to write exploits.¶
While the original motivating use case of this document was firmware encryption, the use of SUIT manifests has been extended to other use cases requiring integrity and confidentiality protection, such as:¶
Hence, we use the term payload to generically refer to all those objects.¶
The payload is encrypted using a symmetric content encryption key, which can be established using a variety of mechanisms; this document defines two content key distribution methods for use with the IETF SUIT manifest, namely:¶
The former method relies on asymmetric key cryptography while the latter uses symmetric key cryptography.¶
Our goal was to reduce the number of content key distribution methods for use with payload encryption and thereby increase interoperability between different SUIT manifest parser implementations.¶
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.¶
This document assumes familiarity with the IETF SUIT manifest [I-D.ietf-suit-manifest], the SUIT information model [RFC9124], and the SUIT architecture [RFC9019].¶
The following abbreviations are used in this document:¶
The terms sender and recipient have the following meaning:¶
Additionally, we introduce the term "distribution system" (or distributor) to refer to an entity that knows the recipients of payloads. It is important to note that the distribution system is far more than a file server. For use of encryption, the distribution system either knows the public key of the recipient (for ES-DH), or the KEK (for AES-KW).¶
The author, which is responsible for creating the payload, does not know the recipients.¶
The author and the distribution system are logical roles. In some deployments these roles are separated in different physical entities and in others they are co-located.¶
[RFC9019] describes the architecture for distributing payloads and manifests from an author to devices. It does, however, not detail the use of payload encryption. This document enhances the architecture to support encryption.¶
Figure 1 shows the distribution system, which represents a file server and the device management infrastructure.¶
The sender (author) needs to know the recipient (device) to use encryption. For AES-KW, the KEK needs to be known and, in case of ES-DH, the sender needs to be in possession of the public key of the recipient. The public key and parameters may be in the recipient's X.509 certificate [RFC5280]. For authentication of the sender and for integrity protection the recipients must be provisioned with a trust anchor when a manifest is protected using a digital signature. When a MAC is used to protect the manifest then a symmetric key must be shared by the recipient and the sender.¶
With encryption, the author cannot just create a manifest for the payload and sign it, since the subsequent encryption step by the distribution system would invalidate the signature over the manifest. (The content key distribution information is embedded inside the COSE_Encrypt structure, which is included in the SUIT manifest.) Hence, the author has to collaborate with the distribution system. The varying degree of collaboration is discussed below.¶
The author has several deployment options, namely:¶
If the author and distributor are separate entities, then the author must delegate encryption rights to the distributor. By the principle of least privilege, this delegation should only grant the distributor decryption and re-encryption rights. There are two models:¶
These two models also present different threat profiles for the distributor. If the distributor only has encryption rights, then an attacker who breaches the distributor can only mount a limited attack: they can encrypt a modified binary, but the recipients will identify the attack as soon as they perform the required image digest check and revert back to a correct image immediately.¶
It is RECOMMENDED that distributors are implemented using a two-manifest system in order to distribute content encryption keys without requiring re-signing of the manifest, despite the increase in complexity and greater number of signature verifications that this imposes on the recipient.¶
This specification introduces a new extension to the SUIT_Parameters structure.¶
The SUIT_Encryption_Info structure (called suit-parameter-encryption-info in Figure 2) contains the content key distribution information. The content of the SUIT_Encryption_Info structure is explained in Section 6.1 (for AES-KW) and in Section 6.2 (for ES-DH).¶
Once a CEK is available, the steps described in Section 6.3 are applicable. These steps apply to both content key distribution methods described in this section.¶
The SUIT_Encryption_Info structure is either carried inside the suit-directive-override-parameters or the suit-directive-set-parameters parameters used in the "Directive Write" and "Directive Copy" directives. An implementation claiming conformance with this specification must implement support for these two parameters. Since a device will typically only support one of the content key distribution algorithms, the distribution system needs to know about the properties of the deployed devices. Mandating only a single content key distribution algorithm for a constrained device also reduces the code size.¶
RFC Editor's Note (TBD1): The value for the suit-parameter-encryption-info parameter is set to 19, as the proposed value.]¶
This specification extends these directives:¶
Examples of the two directives are shown below.¶
Figure 3 illustrates the Directive Write. The encrypted payload specified with parameter-content, namely h'EA1...CED' in the example, is decrypted using the SUIT_Encryption_Info structure referred to by parameter-encryption-info, i.e., h'D86...1F0'. The resulting plaintext payload is stored into component #0.¶
Figure 4 illustrates the Directive Copy. In this example the encrypted payload is found at the URI indicated by the parameter-uri, i.e. "http://example.com/encrypted.bin". The encrypted payload will be downloaded and stored in component #1. Then, the information in the SUIT_Encryption_Info structure of the parameter-encryption-info, i.e. h'D86...1F0', will be used to decrypt the content in component #1 and the resulting plaintext payload will be stored into component #0.¶
The payload to be encrypted may be detached and, in that case, it is not covered by the digital signature or the MAC protecting the manifest. (To be more precise, the suit-authentication-wrapper found in the envelope contains a digest of the manifest in the SUIT Digest Container.)¶
The lack of authentication and integrity protection of the payload is particularly a concern when a cipher without integrity protection is used.¶
To provide authentication and integrity protection of the payload in the detached payload case a SUIT Digest Container with the hash of the encrypted and/or plaintext payload MUST be included in the manifest. See suit-parameter-image-digest parameter in Section 8.4.8.6 of [I-D.ietf-suit-manifest].¶
Once a CEK is available, the steps described in Section 6.3 are applicable. These steps apply to both content key distribution methods.¶
Another attack concerns battery exhaustion. An attacker may swap detached payloads and thereby force the device to process a wrong payload. While this attack will be detected, a device may have performed energy-expensive flash operations already. These operations may reduce the lifetime of devices when they are battery powered Iot devices. See Section 7 for further discussion about IoT devices using flash memory.¶
Including the digest of the encrypted payload allows the device to detect a battery exhaustion attack before energy consuming decryption and flash operations took place. Including the digest of the plaintext payload is adequate when battery exhaustion attacks are not a concern.¶
The sub-sections below describe two content key distribution methods, namely AES Key Wrap (AES-KW) and Ephemeral-Static Diffie-Hellman (ES-DH). Many other methods are specified in the literature, and even supported by COSE. New methods can be added via enhancements to this specification. The two specified methods were selected to their maturity, different security properties, and to ensure interoperability in deployments.¶
When an encrypted payload is sent to multiple recipients, there are different deployment options. To explain these options we use the following notation:¶
- KEK(R1, S) refers to a KEK shared between recipient R1 and the sender S. The KEK, as a concept, is used by AES Key Wrap but not by ES-DH. - CEK(R1, S) refers to a CEK shared between R1 and S. - CEK(*, S) or KEK(*, S) are used when a single CEK or a single KEK is shared with all authorized recipients by a given sender S in a certain context. - ENC(plaintext, k) refers to the encryption of plaintext with a key k.¶
The AES Key Wrap (AES-KW) algorithm is described in [RFC3394], and can be used to encrypt a randomly generated content-encryption key (CEK) with a pre-shared key-encryption key (KEK). The COSE conventions for using AES-KW are specified in Section 8.5.2 of [RFC9052] and in Section 6.2.1 of [RFC9053]. The encrypted CEK is carried in the COSE_recipient structure alongside the information needed for AES-KW. The COSE_recipient structure, which is a substructure of the COSE_Encrypt structure, contains the CEK encrypted by the KEK.¶
The COSE_Encrypt structure conveys information for encrypting the payload, which includes information like the algorithm and the IV, even though the payload may not be embedded in the COSE_Encrypt.ciphertext if it is conveyed as detached content.¶
There are three deployment options for use with AES Key Wrap for payload encryption:¶
1. Fetch KEK(*, S) 2. Generate CEK 3. ENC(CEK, KEK) 4. ENC(payload, CEK)¶
1. Generate CEK 2. for i=1 to n { 2a. Fetch KEK(Ri, S) 2b. ENC(CEK, KEK(Ri, S)) } 3. ENC(payload, CEK)¶
1. for i=1 to n { 1a. Fetch KEK(Ri, S) 1b. Generate CEK(Ri, S) 1c. ENC(CEK(Ri, S), KEK(Ri, S)) 1d. ENC(payload, CEK(Ri, S)) 2. }¶
The CDDL for the COSE_Encrypt_Tagged structure is shown in Figure 5. empty_or_serialized_map and header_map are structures defined in [RFC9052].¶
Note that the AES-KW algorithm, as defined in Section 2.2.3.1 of [RFC3394], does not have public parameters that vary on a per-invocation basis. Hence, the protected header in the COSE_recipient structure is a byte string of zero length.¶
This example uses the following parameters:¶
The COSE_Encrypt structure, in hex format, is (with a line break inserted):¶
D8608443A10101A1054C26682306D4FB28CA01B43B80F68340A2012204456B69642D 315818AF09622B4F40F17930129D18D0CEA46F159C49E7F68B644D¶
The resulting COSE_Encrypt structure in a diagnostic format is shown in Figure 6.¶
The encrypted payload (with a line feed added) was:¶
CE9AB65E7591EE38669C4CCA7A58FA324C1A0DBFDBC2C7C057376AFB805D 660048310E8DAB045A2BE0A93F014FC9¶
Ephemeral-Static Diffie-Hellman (ES-DH) is a scheme that provides public key encryption given a recipient's public key. There are multiple variants of this scheme; this document re-uses the variant specified in Section 8.5.5 of [RFC9052].¶
The following two layer structure is used:¶
As a result, the two layers combine ES-DH with AES-KW and HKDF. An example is given in Figure 9.¶
There are two deployment options with this approach. We assume that recipients are always configured with a device-unique public / private key pair.¶
The steps taken by the sender are:¶
1. Generate CEK 2. for i=1 to n { 2a. Generate KEK(Ri, S) using ES-DH 2b. ENC(CEK, KEK(Ri, S)) } 3. ENC(payload,CEK)¶
1. for i=1 to n { 1a. Generate KEK(Ri, S) using ES-DH 1b. Generate CEK(Ri, S) 1c. ENC(CEK(Ri, S), KEK(Ri, S)) 1d. ENC(payload, CEK(Ri, S)) }¶
The CDDL for the COSE_Encrypt_Tagged structure is shown in Figure 7. Only the minimum number of parameters is shown. empty_or_serialized_map and header_map are structures defined in [RFC9052].¶
See Section 6.3 for a description on how to encrypt the payload.¶
The context information structure is used to ensure that the derived keying material is "bound" to the context of the transaction. This specification re-uses the structure defined in Section 5.2 of RFC 9053 and tailors it accordingly.¶
The following information elements are bound to the context:¶
The sender and recipient identities are left empty.¶
The following fields in Figure 8 require an explanation:¶
The HKDF-based key derivation function MAY contain a salt value, as described in Section 5.1 of [RFC9053]. This optional value is used to influence the key generation process. This specification does not mandate the use of a salt value. If the salt is public and carried in the message, then the "salt" algorithm header parameter MUST be used. The purpose of the salt is to provide extra randomness in the KDF context. If the salt is sent in the 'salt' algorithm header parameter, then the receiver MUST be able to process the salt and MUST pass it into the key derivation function. For more information about the salt, see [RFC5869] and NIST SP800-56 [SP800-56].¶
Profiles of this specification MAY specify an extended version of the context information structure or MAY utilize a different context information structure.¶
This example uses the following parameters:¶
The COSE_Encrypt structure, in hex format, is (with a line break inserted):¶
D8608443A10101A105503517CE3E78AC2BF3D1CDFDAF955E8600F6818344 A101381CA220A401022001215820AAE9A733DEF11E9160A66BD81CC8215F 045ACAC3F8490C7749D58A627323624A22582008A7B88B7F00762BA0919C A065ABF45C2A303B483E86D674E50B015122F8E51504456B69642D325818 0A44E77C3DBBB0780F2DB42C64FD325D18FBE13A25A9369D¶
The resulting COSE_Encrypt structure in a diagnostic format is shown in Figure 9. Note that the COSE_Encrypt structure also needs to protected by a COSE_Sign1, which is not shown below.¶
The encrypted payload (with a line feed added) was:¶
B94272BD7C7E9A144D12CF46D9CEE6318753574A6F780829B87911BE1CF2 B24477BA4E7D1337541F308010088920¶
This section summarizes the steps taken for content encryption, which applies to both content key distribution methods.¶
For use with AEAD ciphers, the COSE specification requires a consistent byte stream for the authenticated data structure to be created. This structure is shown in Figure 10 and is defined in Section 5.3 of [RFC9052].¶
This Enc_structure needs to be populated as follows:¶
The protected field in the Enc_structure from Figure 10 refers to the content of the protected field from the COSE_Encrypt structure.¶
The value of the external_aad MUST be set to a zero-length byte string, i.e., h'' in diagnostic notation and encoded as 0x40.¶
For use with ciphers that do not provide integrity protection, such as AES-CTR and AES-CBC (see [I-D.ietf-cose-aes-ctr-and-cbc]), the Enc_structure shown in Figure 10 MUST NOT be used because the Enc_structure represents the Additional Authenticated Data (AAD) byte string consumable only by AEAD ciphers. Hence, the Additional Authenticated Data structure is not supplied to the API of the cipher. The protected header in the SUIT_Encryption_Info_AESKW or SUIT_Encryption_Info_ESDH structure MUST be a zero-length byte string, respectively.¶
Note: This section is specific to firmware images and does not apply to generic software, configuration data, and machine learning models.¶
Flash memory on microcontrollers is a type of non-volatile memory that erases data in units called blocks, pages, or sectors and re-writes data at the byte level (often 4-bytes) or larger units. Flash memory is furthermore segmented into different memory regions, which store the bootloader, different versions of firmware images (in so-called slots), and configuration data. Figure 11 shows an example layout of a microcontroller flash area. The primary slot typically contains the firmware image to be executed by the bootloader, which is a common deployment on devices that do not offer the concept of position independent code. Position independent code is not a feature frequently found in real-time operating systems used on microcontrollers. There are many flavors of embedded devices, the market is large and fragmented. Hence, it is likely that some implementations and deployments implement their firmware update procedure different than described below. On a positive note, the SUIT manifest allows different deployment scenarios to be supported easily thanks to the "scripting" functionality offered by the commands.¶
When the encrypted firmware image has been transferred to the device, it will typically be stored in a staging area, in the secondary slot in our example.¶
At the next boot, the bootloader will recognize a new firmware image in the secondary slot and will start decrypting the downloaded image sector-by-sector and will swap it with the image found in the primary slot.¶
The swap will only take place after the signature on the plaintext is verified. Note that the plaintext firmware image is available in the primary slot only after the swap has been completed, unless "dummy decrypt" is used to compute the hash over the plaintext prior to executing the decrypt operation during a swap. Dummy decryption here refers to the decryption of the firmware image found in the secondary slot sector-by-sector and computing a rolling hash over the resulting plaintext firmware image (also sector-by-sector) without performing the swap operation. While there are performance optimizations possible, such as conveying hashes for each sector in the manifest rather than a hash of the entire firmware image, such optimizations are not described in this specification.¶
This approach of swapping the newly downloaded image with the previously valid image requires two slots to allow the update to be reversed in case the newly obtained firmware image fails to boot. This approach adds robustness to the firmware update procedure.¶
Since the image in primary slot is available in cleartext, it may need to be re-encrypted before copying it to the secondary slot. This may be necessary when the secondary slot has different access permissions or when the staging area is located in off-chip flash memory and is therefore more vulnerable to physical attacks. Note that this description assumes that the processor does not execute encrypted memory by using on-the-fly decryption in hardware.¶
The ability to restart an interrupted firmware update is often a requirement for low-end IoT devices. To fulfill this requirement it is necessary to chunk a firmware image into sectors and to encrypt each sector individually using a cipher that does not increase the size of the resulting ciphertext (i.e., by not adding an authentication tag after each encrypted block).¶
When an update gets aborted while the bootloader is decrypting the newly obtained image and swapping the sectors, the bootloader can restart where it left off. This technique offers robustness and better performance.¶
For this purpose, ciphers without integrity protection are used to encrypt the firmware image. Integrity protection of the firmware image MUST be provided and the suit-parameter-image-digest, defined in Section 8.4.8.6 of [I-D.ietf-suit-manifest], MUST be used.¶
[I-D.ietf-cose-aes-ctr-and-cbc] registers AES Counter (AES-CTR) mode and AES Cipher Block Chaining (AES-CBC) ciphers that do not offer integrity protection. These ciphers are useful for use cases that require firmware encryption on IoT devices. For many other use cases where software packages, configuration information or personalization data need to be encrypted, the use of Authenticated Encryption with Associated Data (AEAD) ciphers is RECOMMENDED.¶
The following sub-sections provide further information about the initialization vector (IV) selection for use with AES-CBC and AES-CTR in the firmware encryption context. An IV MUST NOT be re-used when the same key is used. For this application, the IVs are not random but rather based on the slot/sector-combination in flash memory. The text below assumes that the block-size of AES is (much) smaller than the sector size. The typical sector-size of flash memory is in the order of KiB. Hence, multiple AES blocks need to be decrypted until an entire sector is completed.¶
In AES-CBC, a single IV is used for encryption of firmware belonging to a single sector, since individual AES blocks are chained together, as shown in Figure 12. The numbering of sectors in a slot MUST start with zero (0) and MUST increase by one with every sector till the end of the slot is reached. The IV follows this numbering.¶
For example, let us assume the slot size of a specific flash controller on an IoT device is 64 KiB, the sector size 4096 bytes (4 KiB) and AES-128-CBC uses an AES-block size of 128 bit (16 bytes). Hence, sector 0 needs 4096/16=256 AES-128-CBC operations using IV 0. If the firmware image fills the entire slot, then that slot contains 16 sectors, i.e. IVs ranging from 0 to 15.¶
Unlike AES-CBC, AES-CTR uses an IV per AES operation, as shown in Figure 13. Hence, when an image is encrypted using AES-CTR-128 or AES-CTR-256, the IV MUST start with zero (0) and MUST be incremented by one for each 16-byte plaintext block within the entire slot.¶
Using the previous example with a slot size of 64 KiB, the sector size 4096 bytes and the AES plaintext block size of 16 byte requires IVs from 0 to 255 in the first sector and 16 * 256 IVs for the remaining sectors in the slot.¶
The following manifests exemplify how to deliver encrypted payload and its encryption info to devices.¶
The examples are signed using the following ECDSA secp256r1 key:¶
-----BEGIN PRIVATE KEY----- MIGHAgEAMBMGByqGSM49AgEGCCqGSM49AwEHBG0wawIBAQQgApZYjZCUGLM50VBC CjYStX+09jGmnyJPrpDLTz/hiXOhRANCAASEloEarguqq9JhVxie7NomvqqL8Rtv P+bitWWchdvArTsfKktsCYExwKNtrNHXi9OB3N+wnAUtszmR23M4tKiW -----END PRIVATE KEY-----¶
The corresponding public key can be used to verify these examples:¶
-----BEGIN PUBLIC KEY----- MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEhJaBGq4LqqvSYVcYnuzaJr6qi/Eb bz/m4rVlnIXbwK07HypLbAmBMcCjbazR14vTgdzfsJwFLbM5kdtzOLSolg== -----END PUBLIC KEY-----¶
Each example uses SHA-256 as the digest function.¶
The following SUIT manifest requests a parser to write and to decrypt the encrypted payload into a component with the suit-directive-write directive.¶
The SUIT manifest in diagnostic notation (with line breaks added for readability) is shown here:¶
/ SUIT_Envelope_Tagged / 107({ / authentication-wrapper / 2: << [ << [ / digest-algorithm-id: / -16 / SHA256 /, / digest-bytes: / h'5DEFDDB7F175FA20778FFE24BE7B9C36 9BD8ED06AA4654F28794CD134CDBA932' ] >>, << / COSE_Sign1_Tagged / 18([ / protected: / << { / algorithm-id / 1: -7 / ES256 / } >>, / unprotected: / {}, / payload: / null, / signature: / h'4C4A5FB50738699649BA439237D20ADC ADD6EC634A800A8E093733FC1C64984B F2BFEC583C124B5546BF0CDAC543AB09 95589543B434951A29A40000EC56CBE7' ]) >> ] >>, / manifest / 3: << { / manifest-version / 1: 1, / manifest-sequence-number / 2: 1, / common / 3: << { / components / 2: [ ['plaintext-firmware'], ] } >>, / install / 17: << [ / fetch encrypted firmware / / directive-override-parameters / 20, { / parameter-content / 18: h'CE9AB65E7591EE38669C4CCA7A58FA324C1A0DBFDBC2C7 C057376AFB805D660048310E8DAB045A2BE0A93F014FC9', / parameter-encryption-info / 19: << 96([ / protected: / << { / alg / 1: 1 / AES-GCM-128 / } >>, / unprotected: / { / IV / 5: h'11D40BB56C3836AD44B39835B3ABC7FC' }, / payload: / null / detached ciphertext /, / recipients: / [ [ / protected: / << { } >>, / unprotected: / { / alg / 1: -3 / A128KW /, / kid / 4: 'kid-1' }, / payload: / h'E01F4443C88CA89DF93A9C7E6D79D1C9BC330757C7D2D75A' / CEK encrypted with KEK / ] ] ]) >> }, / decrypt encrypted firmware / / directive-write / 18, 15 / consumes the SUIT_Encryption_Info above / ] >> } >> })¶
In hex format, the SUIT manifest is this:¶
D86BA2025873825824822F58205DEFDDB7F175FA20778FFE24BE7B9C369B D8ED06AA4654F28794CD134CDBA932584AD28443A10126A0F658404C4A5F B50738699649BA439237D20ADCADD6EC634A800A8E093733FC1C64984BF2 BFEC583C124B5546BF0CDAC543AB0995589543B434951A29A40000EC56CB E703589DA4010102010357A102818152706C61696E746578742D6669726D 7761726511587C8414A212582ECE9AB65E7591EE38669C4CCA7A58FA324C 1A0DBFDBC2C7C057376AFB805D660048310E8DAB045A2BE0A93F014FC913 5843D8608443A10101A1055011D40BB56C3836AD44B39835B3ABC7FCF681 8341A0A2012204456B69642D315818E01F4443C88CA89DF93A9C7E6D79D1 C9BC330757C7D2D75A120F¶
The following SUIT manifest requests a parser to fetch the encrypted payload and to stores it. Then, the payload is decrypted and stored into another component with the suit-directive-copy directive. This approach works well on constrained devices with execute-in-place flash memory.¶
The SUIT manifest in diagnostic notation (with line breaks added for readability) is shown here:¶
/ SUIT_Envelope_Tagged / 107({ / authentication-wrapper / 2: << [ << [ / digest-algorithm-id: / -16 / SHA256 /, / digest-bytes: / h'C6A66263CCF4C6FF5992AE4074B30DDD 34520AA099F6BAD96B2F60FE79F07EC4' ] >>, << / COSE_Sign1_Tagged / 18([ / protected: / << { / algorithm-id / 1: -7 / ES256 / } >>, / unprotected: / {}, / payload: / null, / signature: / h'DA08C3A6455FF30865A97A7F4FBC3BA1 5F954E39B57167DEA9FE16EBA12CFE33 D58790DB64CB70A08F89513B15CFF995 1222868195224E1AB87D46FA37F58864' ]) >> ] >>, / manifest / 3: << { / manifest-version / 1: 1, / manifest-sequence-number / 2: 1, / common / 3: << { / components / 2: [ ['plaintext-firmware'], ['encrypted-firmware'] ] } >>, / install / 17: << [ / fetch encrypted firmware / / directive-set-component-index / 12, 1 / ['encrypted-firmware'] /, / directive-override-parameters / 20, { / parameter-image-size / 14: 46, / parameter-uri / 21: "https://example.com/encrypted-firmware" }, / directive-fetch / 21, 15, / decrypt encrypted firmware / / directive-set-component-index / 12, 0 / ['plaintext-firmware'] /, / directive-override-parameters / 20, { / parameter-encryption-info / 19: << 96([ / protected: / << { / alg / 1: 1 / AES-GCM-128 / } >>, / unprotected: / { / IV / 5: h'11D40BB56C3836AD44B39835B3ABC7FC' }, / payload: / null / detached ciphertext /, / recipients: / [ [ / protected: / << { } >>, / unprotected: / { / alg / 1: -3 / A128KW /, / kid / 4: 'kid-1' }, / payload: / h'E01F4443C88CA89DF93A9C7E6D79D1C9BC330757C7D2D75A' / CEK encrypted with KEK / ] ] ]) >>, / parameter-source-component / 22: 1 / ['encrypted-firmware'] / }, / directive-copy / 22, 15 / consumes the SUIT_Encryption_Info above / ] >> } >> })¶
In hex format, the SUIT manifest is this:¶
D86BA2025873825824822F5820C6A66263CCF4C6FF5992AE4074B30DDD34 520AA099F6BAD96B2F60FE79F07EC4584AD28443A10126A0F65840DA08C3 A6455FF30865A97A7F4FBC3BA15F954E39B57167DEA9FE16EBA12CFE33D5 8790DB64CB70A08F89513B15CFF9951222868195224E1AB87D46FA37F588 640358E5A40101020103582BA102828152706C61696E746578742D666972 6D776172658152656E637279707465642D6669726D776172651158AF900C 0114A20E182E15782668747470733A2F2F6578616D706C652E636F6D2F65 6E637279707465642D6669726D77617265150F0C0014A2135843D8608443 A10101A1055011D40BB56C3836AD44B39835B3ABC7FCF6818341A0A20122 04456B69642D315818E01F4443C88CA89DF93A9C7E6D79D1C9BC330757C7 D2D75A1601160F14A2035824822F582036921488FE6680712F734E11F58D 87EEB66D4B21A8A1AD3441060814DA16D50F0E181E030F¶
The algorithms described in this document assume that the party performing payload encryption¶
Both cases require some upfront communication interaction to distribute these keys to the involved communication parties. This interaction may be provided by a device management protocol, as described in [RFC9019], or may be executed earlier in the lifecycle of the device, for example during manufacturing or during commissioning. In addition to the keying material key identifiers and algorithm information need to be provisioned. This specification places no requirements on the structure of the key identifier.¶
To provide high security for AES Key Wrap, it is important that the KEK is of high entropy, and that implementations protect the KEK from disclosure. Compromise of the KEK may result in the disclosure of all key data protected with that KEK.¶
Since the CEK is randomly generated, it must be ensured that the guidelines for random number generation in [RFC8937] are followed.¶
In some cases third party companies analyse binaries for known security vulnerabilities. With encrypted payloads, this type of analysis is prevented. Consequently, these third party companies either need to be given access to the plaintext binary before encryption or they need to become authorized recipients of the encrypted payloads. In either case, it is necessary to explicitly consider those third parties in the software supply chain when such a binary analysis is desired.¶
IANA is asked to add the following value to the SUIT Parameters registry established by Section 11.5 of [I-D.ietf-suit-manifest]:¶
Label Name Reference ----------------------------------------- TBD1 Encryption Info Section 4¶
[Editor's Note: TBD1: Proposed 19]¶
The following CDDL must be appended to the SUIT Manifest CDDL. The SUIT CDDL is defined in Appendix A of [I-D.ietf-suit-manifest]¶
; Define SUIT_Encryption_Info_* as a subset of COSE_Encrypt SUIT_Encryption_Info_Value = #6.96( SUIT_Encryption_Info_AESKW .within COSE_Encrypt / SUIT_Encryption_Info_ESDH .within COSE_Encrypt) SUIT_Encryption_Info_AESKW = [ protected : bstr .cbor outer_header_map_protected, unprotected : outer_header_map_unprotected, ciphertext : bstr / nil, recipients : [ + COSE_recipient_AESKW .within COSE_recipient ] ] COSE_recipient_AESKW = [ protected : bstr .size 0 / bstr .cbor empty_map, unprotected : recipient_header_unpr_map_aeskw, ciphertext : bstr ; CEK encrypted with KEK ] empty_map = {} recipient_header_unpr_map_aeskw = { 1 => int, ; algorithm identifier ? 4 => bstr, ; identifier of the recipient public key * label => values ; extension point } SUIT_Encryption_Info_ESDH = [ protected : bstr .cbor outer_header_map_protected, unprotected : outer_header_map_unprotected, ciphertext : bstr / nil, recipients : [ + COSE_recipient_ESDH .within COSE_recipient ] ] COSE_recipient_ESDH = [ protected : bstr .cbor recipient_header_map_esdh, unprotected : recipient_header_unpr_map_esdh, ciphertext : bstr ; CEK encrypted with KEK ] recipient_header_map_esdh = { 1 => int, ; algorithm identifier * label => values ; extension point } recipient_header_unpr_map_esdh = { -1 => COSE_Key, ; ephemeral public key for the sender ? 4 => bstr, ; identifier of the recipient public key * label => values ; extension point } ; common definitions outer_header_map_protected = { 1 => int, ; algorithm identifier * label => values ; extension point } outer_header_map_unprotected = { 5 => bstr, ; IV * label => values ; extension point } ; Extends SUIT Manifest $$SUIT_Parameters //= (suit-parameter-encryption-info => bstr .cbor SUIT_Encryption_Info_Value) suit-parameter-encryption-info = 19¶
We would like to thank Henk Birkholz for his feedback on the CDDL description in this document. Additionally, we would like to thank Michael Richardson, Øyvind Rønningstad, Dave Thaler, Laurence Lundblade, Christian Amsüss, and Carsten Bormann for their review feedback. Finally, we would like to thank Dick Brooks for making us aware of the challenges encryption imposes on binary analysis.¶