How to extend the running application into PCR? and Which PCR can be used for it?
How to extend the running application into PCR?
2.2k Views Asked by Geek At
1
There are 1 best solutions below
Related Questions in TPM
- What could be causing TPM_RC_COMMAND_SIZE error (0x80010000000a00000142) in response to TPM_GETRANDOM?
- TPM 2.0 based TLS handshake fails against RSA-4k Server keys (out-of-range)
- Why OpenSSL doesn`t work with PKCS11-URI?
- Support curl tpm2 access like openssl via handles?
- TPM Key Generation
- Difference between Trusted Platform Module (TPM) and Secure Element (SE)
- Store and retrieve a symmetric AES key in the TPM on windows
- How to Ensure Imported Keys Are Non-Exportable in TPM 2.0?
- TPM issue: error in session attributes of NV_define when trying to connect PCR policy
- How to include TSS.CPP in another Visual Studio Project
- how to securely give access to the container to use private key stored in TPM
- Can TPM2 NVM encrypt data?
- HttpWebRequest returns 403 in Windows Server 2019 to url:microsoft.com
- TPM2 NVM write in EDK2 EFI_DEVICE_ERROR
- How to verify TPM-generated signatures with OpenSSL?
Related Questions in TRUSTED-COMPUTING
- Difference between Trusted Platform Module (TPM) and Secure Element (SE)
- For TPM 1.2, using tpm-tools the tpm_sealdata does not work after a reboot
- Reconstruction of PCR register from ASCII measurements
- Go lang tpm2 library PCR extend, PCR read inconsistency
- Secure management of local counter on Android
- Can Android app on ChromeOS create a KeyPair that is at least SECURITY_LEVEL_TRUSTED_ENVIRONMENT?
- Support of Intel's MLE / DRTM in long mode
- Can we prevent EC2 instance from accessing the plain text data when using the AWS Nitro Enclave for encryption?
- Undefined reference to Tss2_TctiLdr_Initialize
- Should switching between RSASSA-PSS and RSASSA-PKCS1-v1_5 be mindful of other parameters?
- file path of each hash in measurements with TPM
- how to enable TPM measured boot and see pcr values in windows 10?
- What TPM2_GetCapability TPM_HT_LOADED_SESSION is intended to show?
- How to load and use a persistent symmetric key in the TPM?
- TPM: PCR_Event VS PCR_Extend
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
I assume you mean a TPM version 1.2 on a PC platform, so the following specification documents are of interest for you:
Now to your questions:
"How to extend the running application into PCR?"
You need some piece of software that identifies "the running application" (=measure) and issue a
TPM_Extendcommand to the TPM. Usually this is done through a TSS, but you can also do that with a self written program, theTPM_Extendcommand is not that complex.Identifying means calculating a SHA-1 hash in most cases, but the TPM does not care. The description of the data you provide is:
"Which PCR can be used for it?"
This depends on your actual environment. Access to PCRs are controlled by localities. Here is a table showing which PCR can be extended in which locality:
Which locality you are in depends on your environment. If you are in a Linux userspace, for exmaple, you have locality 0.
If you are designing a trusted architecture you will also have to consider how the PCRs can be reset (in which localities).
The localities are described in TCG PC Client Specific TPM Interface Specification (TIS):
Locality 4: Trusted hardware component. This is used by the D-CRTM to establish the Dynamic RTM.
Locality 3: Auxiliary components. Use of this is optional and, if used, it is implementation dependent.
Locality 2: Dynamically Launched OS (Dynamic OS) “runtime” environment.
Locality 1: An environment for use by the Dynamic OS.
Locality 0: The Static RTM, its chain of trust and its environment.