System and method for verifying the integrity and authorization of software before execution in a local platform
First Claim
Patent Images
1. A method comprising:
- providing information to a platform operating in a pre-boot operational state, the information including (1) an image of a boot application to be executed by the platform during a boot procedure, and (2) a signed manifest separate from the boot application, the signed manifest including (i) a secure hash value that includes a plurality of hash values having a one-to-one correspondence with a plurality of sub-images forming the image of the boot application, (ii) a manifest digital signature that includes the plurality of hash values collectively signed with a private key of a selected signatory, and (iii) a certificate chain;
verifying integrity of the boot application downloaded to the platform; and
upon determining that an authorization check enable flag of the platform is enabled, determining whether the boot application is authorized to be executed by the platform by (1) accessing contents from each digital certificate of the certificate chain to obtain a public key of a signatory, (2) comparing a subject public key within each digital certificate with a public key of the signatory of the manifest digital signature, and (3) authorizing execution of the boot application if the subject public key matches the public key of the signatory.
1 Assignment
0 Petitions
Accused Products
Abstract
A method to verify integrity of information and selectively determine whether the information is authorized to be executed by the platform. The information is downloaded to a platform operating in a pre-boot operational state.
-
Citations
10 Claims
-
1. A method comprising:
-
providing information to a platform operating in a pre-boot operational state, the information including (1) an image of a boot application to be executed by the platform during a boot procedure, and (2) a signed manifest separate from the boot application, the signed manifest including (i) a secure hash value that includes a plurality of hash values having a one-to-one correspondence with a plurality of sub-images forming the image of the boot application, (ii) a manifest digital signature that includes the plurality of hash values collectively signed with a private key of a selected signatory, and (iii) a certificate chain;
verifying integrity of the boot application downloaded to the platform; and
upon determining that an authorization check enable flag of the platform is enabled, determining whether the boot application is authorized to be executed by the platform by (1) accessing contents from each digital certificate of the certificate chain to obtain a public key of a signatory, (2) comparing a subject public key within each digital certificate with a public key of the signatory of the manifest digital signature, and (3) authorizing execution of the boot application if the subject public key matches the public key of the signatory. - View Dependent Claims (2, 3, 4, 5, 6, 7)
-
-
8. A platform comprising:
-
a processor; and
a persistent storage device in communication with the processor, the persistent storage device including an authorization certificate including a public key of a source downloading a boot image to the platform, an authorization check enable flag to signal a verification function to verify that the source is authorized to download the boot image; and
a verification function being software to be executed by the processor to verify whether the downloaded boot image has been modified, the verification function being configured to receive information from a first source while the platform is in a pre-boot operational state, the information to include (1) an image of a boot application to be executed by the platform during a boot procedure, and (2) a signed manifest separate from the boot application, the signed manifest to include (i) a secure hash value to include a plurality of hash values to have a one-to-one correspondence with a plurality of sub-images to form the image of the boot application, (ii) a manifest digital signature to include the plurality of hash values to be collectively signed with a private key of a selected signatory, and (iii) a certificate chain, and when the authorization check enable flag is enabled, determine. whether the boot application is authorized for execution by the platform by (1) accessing contents from each digital certificate of the certificate chain to obtain a public key of a signatory, (2) comparing a subject public key within each digital certificate with a public key of the signatory of the manifest digital signature, and (3) authorizing execution of the boot application if the subject public key matches the public key of the signatory. - View Dependent Claims (9, 10)
-
Specification