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

Secure upgrade HLD #1024

Merged
merged 32 commits into from
Jan 29, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
9b75f61
Create secure_upgrade.md
ycoheNvidia Jun 30, 2022
45cf2cb
Add files via upload
ycoheNvidia Jun 30, 2022
3d58e5b
Delete build_options.PNG
ycoheNvidia Jun 30, 2022
63b4814
Delete dev_verification_script.PNG
ycoheNvidia Jun 30, 2022
9b2afea
Delete signing_flow.PNG
ycoheNvidia Jun 30, 2022
f977e28
Delete su_installation_flows.PNG
ycoheNvidia Jun 30, 2022
e745525
Add files via upload
ycoheNvidia Jun 30, 2022
0959857
Update secure_upgrade.md
ycoheNvidia Jul 3, 2022
5965dca
Update secure_upgrade.md
ycoheNvidia Jul 3, 2022
1a40100
Update secure_upgrade.md
ycoheNvidia Jul 3, 2022
7ff7865
Update secure_upgrade.md
ycoheNvidia Jul 3, 2022
57b8ba4
Update secure_upgrade.md
ycoheNvidia Jul 3, 2022
64aaaa4
Update secure_upgrade.md
ycoheNvidia Jul 4, 2022
3b52900
Update secure_upgrade.md
ycoheNvidia Jul 4, 2022
6d27685
Update secure_upgrade.md
ycoheNvidia Jul 4, 2022
6f63f87
Update secure_upgrade.md
ycoheNvidia Jul 12, 2022
4d241b1
Delete signing_options.png
ycoheNvidia Jul 24, 2022
0f1f392
Add files via upload
ycoheNvidia Jul 24, 2022
7a09aae
Update secure_upgrade.md
ycoheNvidia Jul 26, 2022
8aec644
Add files via upload
ycoheNvidia Jul 26, 2022
eb43f61
Delete build_options.png
ycoheNvidia Jul 26, 2022
bf3ec59
Add files via upload
ycoheNvidia Jul 26, 2022
943947c
Update secure_upgrade.md
ycoheNvidia Jul 26, 2022
de21fda
Update secure_upgrade.md
ycoheNvidia Jul 27, 2022
2e303e6
Merge branch 'master' into ycoheNvidia-patch-1
ycoheNvidia Aug 15, 2022
8166e5d
Merge branch 'master' into ycoheNvidia-patch-1
liat-grozovik Aug 29, 2022
1b9cd13
[secure upgrade]Fix typos, add source code links, add description of …
davidpil2002 Oct 2, 2022
beb6077
Merge branch 'master' into ycoheNvidia-patch-1
liat-grozovik Oct 18, 2022
9a0064b
Merge branch 'master' into ycoheNvidia-patch-1
liat-grozovik Oct 23, 2022
a338561
Merge branch 'master' into ycoheNvidia-patch-1
liat-grozovik Nov 8, 2022
f32239a
Merge branch 'master' into ycoheNvidia-patch-1
ycoheNvidia Jan 24, 2023
361303e
Merge branch 'master' into ycoheNvidia-patch-1
liat-grozovik Jan 29, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added doc/secure_upgrade/build_options.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/secure_upgrade/dev_verification_script.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
181 changes: 181 additions & 0 deletions doc/secure_upgrade/secure_upgrade.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,181 @@
# Secure upgrade #

## 1. <a name='TableofContent'></a>Table of Content

<!-- vscode-markdown-toc -->
* 1. [Table of Content](#TableofContent)
* 1.1. [Revision](#Revision)
* 1.2. [Scope](#Scope)
* 1.3. [Definitions/Abbreviations](#DefinitionsAbbreviations)
* 1.4. [Overview](#Overview)
* 1.5. [Requirements](#Requirements)
* 1.6. [Architecture Design](#ArchitectureDesign)
* 1.6.1. [Installation Flow](#InstallationFlow)
* 1.6.2. [signing](#signing)
* 1.6.3. [verification](#verification)
* 1.7. [High-Level Design](#High-LevelDesign)
* 1.7.1. [Signing process](#Signingprocess)
* 1.7.2. [Verification process](#Verificationprocess)
* 1.8. [SAI API](#SAIAPI)
* 1.9. [Configuration and management](#Configurationandmanagement)
* 1.9.1. [CLI/YANG model Enhancements](#CLIYANGmodelEnhancements)
* 1.9.2. [Config DB Enhancements](#ConfigDBEnhancements)
* 1.10. [Warmboot and Fastboot Design Impact](#WarmbootandFastbootDesignImpact)
* 1.11. [ Restrictions/Limitations](#RestrictionsLimitations)
* 1.11.1. [ uefi tools and secure boot enabled](#uefitoolsandsecurebootenabled)
* 1.11.2. [ ONIE secure upgrade verification code](#ONIEsecureupgradeverificationcode)
* 1.12. [ Upgrade and downgrade flows](#Upgradeanddowngradeflows)
* 1.12.1. [ secure upgrade from non secured SONIC/ONIE to secured SONIC](#secureupgradefromnonsecuredSONICONIEtosecuredSONIC)
* 1.12.2. [ secure upgrade from secured SONIC to secured SONIC](#secureupgradefromsecuredSONICtosecuredSONIC)
* 1.12.3. [ downgrade from secured SONIC to non-secured SONIC](#downgradefromsecuredSONICtonon-securedSONIC)
* 1.12.4. [secure upgrade from secure upgrade enabled ONIE to secured SONIC](#secureupgradefromsecureupgradeenabledONIEtosecuredSONIC)
* 1.13. [ Testing Requirements/Design](#TestingRequirementsDesign)
* 1.13.1. [Unit Test cases](#UnitTestcases)
* 1.13.2. [System Test cases](#SystemTestcases)
* 1.14. [Open/Action items - if any](#OpenActionitems-ifany)

<!-- vscode-markdown-toc-config
numbering=true
autoSave=true
/vscode-markdown-toc-config -->
<!-- /vscode-markdown-toc -->

### 1.1. <a name='Revision'></a>Revision
Rev | Date | Author | Change Description |
| :---: | :-----: | :--------------: | ------------------ |
| 0.1 | 6/2022 | Yona Cohen | Phase 1 Design |

### 1.2. <a name='Scope'></a>Scope

This secure upgrade hld doc described the requirements, architecture, and general flow details of secure upgrade feature in switches SONIC OS based.

### 1.3. <a name='DefinitionsAbbreviations'></a>Definitions/Abbreviations

SU - secure upgrade
SB - secure boot
CMS - Cryptographic Message Syntax

### 1.4. <a name='Overview'></a>Overview

Secure installation and upgrade of OS are setting a requirement to ensure the image was not modified since it was built by the vendor. This is a basic requirement as part of general OS security. In order to help the credibility of the OS image, secure upgrade mechanism guarantees the image was not modified by any unauthorized entity since its original creation.

### 1.5. <a name='Requirements'></a>Requirements

We want to enable secure upgrade of SONIC. This will include secure upgrade of SONIC while installing SONIC via ONIE or SONIC. The feature requires a signing process which will include a private key and certificate. The verification process on the other end requires a public key certificate for validation. Both processes are required to be supported by various scenarios such as development and release.
In order to do secure installation of SONIC from ONIE, it has to include the following secure upgrade verification code (links): https://github.com/sonic-net/sonic-buildimage/pull/11862, https://github.com/sonic-net/sonic-utilities/pull/2337
Device arch should support secure boot including UEFI tools.

### 1.6. <a name='ArchitectureDesign'></a>Architecture Design
#### 1.6.1. <a name='InstallationFlow'></a>Installation Flow
![su_installation_flows](su_installation_flows.png)

#### 1.6.2. <a name='signing'></a>signing
![signing_flow](signing_flow.png)
(flow description in the chapter below)
#### 1.6.3. <a name='verification'></a>verification
Verification flow calls a verification script during image installation, in (1.7.3.) verification process below.

### 1.7. <a name='High-LevelDesign'></a>High-Level Design


This feature has 2 flows to be supported:

#### 1.7.1. <a name='Signingprocess'></a>Signing process

Sign sonic image during build process in build_image.sh script, right after generation.
We want to add the flag SECURE_UPGRADE_MODE to allow several modes of secure upgrade. When SECURE_UPGRADE_MODE == 'no_sign' no change will be made to the current build process. In case of SECURE_UPGRADE_MODE == 'dev', image will be signed by development script and when SECURE_UPGRADE_MODE == 'prod' - image will be signed by production script. In addition, we want to add the flags SECURE_UPGRADE_DEV_SIGNING_KEY and SECURE_UPGRADE_DEV_SIGNING_CERT, to provide the option to give path for development keys during the build.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How is the signing prod process is different from dev? How do you secure production keys? do you use vault kind of infra?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The feature is including the code that supports secure upgrade using development keys. And any Vendor should decide his own design flow for production.
In general, in the build flow when the user is building the image with "prod" flag (as explained in chapter 1.7.1. Signing process) the build flow will call a signing script that should be coded by the vendor, this script should send the image to a different server "sign server" and this server should return the image signed.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@davidpil2002 , we have a different environment for build production and dev, production is always built in security environment. Is it possible to use the same process for both production and dev? The only different is the certificates used, but the build steps are all the same.
It is good to provide an additional script to sign images from the "sign server", but can we support to the simple scenario to support "sign server" and build on the same machine? How about removing the "DEV" in the parameters?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@xumia thank you for the question. In many cases, different customers have different production servers with different environments. Therefor no single script will be applicable here. In the case you suggest - it is possible to copy the dev key as an argument to prod script, but this is a specific use case

![build_options](build_options.png)
- After image creation, during onie-mk-demo.sh script, we create a new output file with the prefix sharch.sh script and the image. We calculate sha1 and original image size and update them in the prefix for verification during image install.
- We will call a dedicated script to create an image signature:
We will allow the use of 2 script types in this flow -

a. development script - sign_image_dev.sh, which will use simple cms OpenSSL signing (enable with flag set to SECURE_UPGRADE_MODE == 'dev') with development keys (path provided in SECURE_UPGRADE_DEV_SIGNING_KEY and SECURE_UPGRADE_DEV_SIGNING_CERT).

b. production script - sign_image_${platform}.sh (enable with the flag set to SECURE_UPGRADE_MODE == 'prod') that each vendor will be able to provide for themselves. When implementing this script, it is required to implement the method sign_image_prod(){} which is being called with arguments $output_image and $out_signature during the build process and is supposed to create a signature in $out_signature that will be concatenated to the image in the calling build script, afterward.

![signing_options](signing_options.png)

#### 1.7.2. <a name='Verificationprocess'></a>Verification process
- SONIC install – changes will be mainly done in sonic-installer main.py where bootloader methods are being called and will only affect 'sonic-installer install' command (other sonic-installer commands will not be affected). The installation process is triggered by install.sh script, which is different for every platform.
In our opinion, python modifications will be easier to add and maintain than install.sh changes, as changing install.sh (for each platform) will require much more sources to maintain and test (different HW to check on, test cases for each HW, etc.).
- A signed image will go through a verification process before installation, as main.py will call a dedicated bash script to split the signature from the image and check it with a public key certificate.
Verification script called verify_image_sign.sh will verify using OpenSSL cms. Verification is enabled only if efi tools are enabled, and "Secure Boot" flag is enabled in BIOS. Accordingly, the certificate will be fetched from BIOS using EFI tools.
In order to see if secure boot flag is enabled, user can use the linux command 'bootctl status' and look for "Secure Boot: enabled/disabled" line, or use the command:

bootctl status 2>/dev/null | grep "Secure Boot:"

![dev_verification_script](dev_verification_script.png)

### 1.8. <a name='SAIAPI'></a>SAI API

NA

### 1.9. <a name='Configurationandmanagement'></a>Configuration and management

NA

#### 1.9.1. <a name='CLIYANGmodelEnhancements'></a>CLI/YANG model Enhancements

NA

#### 1.9.2. <a name='ConfigDBEnhancements'></a>Config DB Enhancements

NA

### 1.10. <a name='WarmbootandFastbootDesignImpact'></a>Warmboot and Fastboot Design Impact
NA

### 1.11. <a name='RestrictionsLimitations'></a> Restrictions/Limitations
#### 1.11.1. <a name='uefitoolsandsecurebootenabled'></a> uefi tools and secure boot enabled
Device arch should support secure boot including UEFI tools.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what are the UEFI tools being used to support secure upgrade process?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

added the list and url

UEFI tools pkg named efitools, link: https://packages.debian.org/buster/amd64/efitools/filelist
Secure Upgrade feature is using: efi-readvar, sig-list-to-certs tools.
This feature is dependent on BIOS secure boot flag being enabled.
#### 1.11.2. <a name='ONIEsecureupgradeverificationcode'></a> ONIE secure upgrade verification code
Secure installation of SONIC from ONIE requires a specific verification code, which can be picked from the following ONIE pull request TBD (waiting for it to be created)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is the ONIE pull request is ready? please share if it is

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

still not


### 1.12. <a name='Upgradeanddowngradeflows'></a> Upgrade and downgrade flows
we want to discuss the following flows:
#### 1.12.1. <a name='secureupgradefromnonsecuredSONICONIEtosecuredSONIC'></a> secure upgrade from non secured SONIC/ONIE to secured SONIC
In this flow, the signature is not verified as no verification code is available at this stage. If we assume secure upgrade SONIC image is credible, then the upgraded OS will support secure upgrade flow.
#### 1.12.2. <a name='secureupgradefromsecuredSONICtosecuredSONIC'></a> secure upgrade from secured SONIC to secured SONIC
This is the main flow supported by the feature - each signed image will be verified before its installation.
#### 1.12.3. <a name='downgradefromsecuredSONICtonon-securedSONIC'></a> downgrade from secured SONIC to non-secured SONIC
This flow will only be enabled if secure boot BIOS flag is disabled, as we assume users with access to BIOS should have the ability to downgrade the OS version.
#### 1.12.4. <a name='secureupgradefromsecureupgradeenabledONIEtosecuredSONIC'></a>secure upgrade from secure upgrade enabled ONIE to secured SONIC
As mentioned in 1.5 and 1.11.2, this flow requires secure upgrade enabled ONIE, with code available in link TBD.
### 1.13. <a name='TestingRequirementsDesign'></a> Testing Requirements/Design
#### 1.13.1. <a name='UnitTestcases'></a>Unit Test cases
We can use the verification script as part of standalone test cases, without the need to run the whole installation process.
In this test flow, we create a simple mock image, signing it with self-signing keys, and then checking each scenario in a different test case.
We use the verification script verify_image_sign_test.sh which calls the same common script verify_image_sign_common.sh as the image verification script.

- Good flows:

- Verify image - check the basic flow of signing and verification
- Bad flows -
Check if verification catches bad images:
- Verify an image that was modified after the build
- Verify an image with a wrong image size in sharch
- Verify an image with a wrong sha1 in sharch
- Verify an image with a modified signature
- Verify an image signed with one key and verified with a different key

#### 1.13.2. <a name='SystemTestcases'></a>System Test cases
- Good flows
- Install secure image from secure SONIC
- Install secure image from non-secure SONIC
- Install secure image from secure ONIE
- Install secure image from non-secure ONIE
- Install non-secure image from secure SONIC (SB flag is off in BIOS)
- Install a non-secure image from secure ONIE (SB flag is off in BIOS)
- Install a non-secure image from non-secure SONIC (nothing should be changed in this flow)
- Bad flows
- Try to install an unsigned image from SONIC, on secure boot enabled machine.
- Try to install an unsigned image from ONIE, on secure boot enabled machine.
- Try to install a signed image from SONIC, on secure boot enabled machine, while a specific certificate for this image is not available from UEFI.
- Try to install a signed image that was modified after the build process from SONIC, on secure boot enabled machine.

### 1.14. <a name='OpenActionitems-ifany'></a>Open/Action items - if any

NOTE: All the sections and sub-sections given above are mandatory in the design document. Users can add additional sections/sub-sections if required.
Binary file added doc/secure_upgrade/signing_flow.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/secure_upgrade/signing_options.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/secure_upgrade/su_installation_flows.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.