Function report |
Source Code:security\keys\trusted-keys\trusted_tpm1.c |
Create Date:2022-07-28 18:30:19 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:verify the AUTH2_COMMAND (unseal) result from TPM
Proto:static int TSS_checkhmac2(unsigned char *buffer, const uint32_t command, const unsigned char *ononce, const unsigned char *key1, unsigned int keylen1, const unsigned char *key2, unsigned int keylen2, ...)
Type:int
Parameter:
| Type | Parameter | Name |
|---|---|---|
| unsigned char * | buffer | |
| const uint32_t | command | |
| const unsigned char * | ononce | |
| const unsigned char * | key1 | |
| unsigned int | keylen1 | |
| const unsigned char * | key2 | |
| unsigned int | keylen2 |
| 289 | bufsize = LOAD32(buffer, TPM_SIZE_OFFSET) |
| 292 | result = LOAD32N(buffer, TPM_RETURN_OFFSET) |
| 294 | If tag == TPM_TAG_RSP_COMMAND Then Return 0 |
| 296 | If tag != TPM_TAG_RSP_AUTH2_COMMAND Then Return -EINVAL |
| 298 | authdata1 = buffer + bufsize - SHA1_DIGEST_SIZE + 1 + SHA1_DIGEST_SIZE + SHA1_DIGEST_SIZE |
| 300 | authdata2 = buffer + bufsize - SHA1_DIGEST_SIZE |
| 301 | continueflag1 = authdata1 - 1 |
| 302 | continueflag2 = authdata2 - 1 |
| 303 | enonce1 = continueflag1 - TPM_NONCE_SIZE |
| 304 | enonce2 = continueflag2 - TPM_NONCE_SIZE |
| 306 | sdesc = init_sdesc(hashalg) |
| 324 | cycle |
| 326 | If dlen == 0 Then Break |
| 330 | If ret < 0 Then Break |
| 339 | ret = TSS_rawhmac(testhmac1, key1, keylen1, SHA1_DIGEST_SIZE, paramdigest, TPM_NONCE_SIZE, enonce1, TPM_NONCE_SIZE, ononce, 1, continueflag1, 0, 0) |
| 344 | If memcmp(testhmac1, authdata1, SHA1_DIGEST_SIZE) Then |
| 348 | ret = TSS_rawhmac(testhmac2, key2, keylen2, SHA1_DIGEST_SIZE, paramdigest, TPM_NONCE_SIZE, enonce2, TPM_NONCE_SIZE, ononce, 1, continueflag2, 0, 0) |
| 355 | out : |
| 357 | Return ret |
| Name | Describe |
|---|---|
| tpm_unseal | se the AUTH2_COMMAND form of unseal, to authorize both key and blob |
| Source code conversion tool public plug-in interface | X |
|---|---|
| Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |