S32K314 question about TLS API with HSE

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

S32K314 question about TLS API with HSE

跳至解决方案
7,984 次查看
Changhawn
Contributor IV

In S32K314,
We are using Mbedtls RTM 1.0.0 provided by NXP w/ HSE.

After TLS Handshake, we need to compute shared secret, so we are using mbedtls_ecdh_compute_shared() API,

But that API(mbedtls_ecdh_compute_shared) assign key handle as z value parameter like below picture.

In working operation, we need to derive actual shared secret key value, not key handle value. How can we do that? Please guide.

 

TLS Code)

Changhawn_0-1731469557649.png

application code)

uint8_t sharedSecret[32];
 
~~~
 
        rc = mbedtls_ecdh_compute_shared(&ecdh.grp, &z, &ecdh.Qp, &d, myrand, NULL);
        if (rc != 0)
            SYS_CONSOLE_PRINT("!!! mbedtls_ecdh_compute_shared returned %d\r\n", rc);
 
        tmp_rc = mbedtls_mpi_write_binary(&z, sharedSecret, 32);
        if (tmp_rc != 0)
            SYS_CONSOLE_PRINT("!!! mbedtls_mpi_write_binary returned %d\r\n", tmp_rc);
 
        PrintDumpBytes("sharedSecret", sharedSecret, 32);
 
 

test log)

Private keyHandle 0x20400 | Peer KeyHandle : 0x20500 | Shared Secret KeyHandle 0x20600
Z is 20600
sharedSecret=
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 02 06 00

0 项奖励
回复
1 解答
7,786 次查看
Changhawn
Contributor IV

Dear NXP guys.

In KDF,  I know that NIST 800-56A is not supported currently in NXP HSE.

So implemented it without HSE. 

在原帖中查看解决方案

0 项奖励
回复
3 回复数
7,787 次查看
Changhawn
Contributor IV

Dear NXP guys.

In KDF,  I know that NIST 800-56A is not supported currently in NXP HSE.

So implemented it without HSE. 

0 项奖励
回复
7,930 次查看
Changhawn
Contributor IV
Below is the code written on the Platform where HSE is running, that is, with MBEDTLS_USE_NXP_HSE_CRYPTO enabled, after tls handshaked processing is done.
 
It includes the process of generating a derived key using a certificate and DH public key, decrypting the private key through AES, and assigning it to the ECC context, as well as the signature generation process.
 
That is, an encryption key was created using the certificate and DH public key, and the key was derived using mbedtls_ssl_tls_prf(), and then the private key (output) was created through AES and assigned to the ECC context.
 
But, in the authorization req process, the SignatureValue created is responded with a wrong signature in the authorization res.
 
1. For key derivation, use mbedtls_ssl_tls_prf(), label is correct ? or not?
which one "externed master secret" or "key expansion" ?
 
2. Is there anything wrong in the code below?
 
 
certificationInstatllResponse
{
/* omission */
 
    {
        mbedtls_pk_context oem_key;
        mbedtls_ecp_keypair *oem_ecp;
 
        mbedtls_pk_init(&oem_key);
        mbedtls_mpi_init(&d);
 
        rc = mbedtls_pk_parse_key(&oem_key, PKI_1_CRT_OEM_LEAF_VALID_key, PKI_1_CRT_OEM_LEAF_VALID_key_len,
                                  gq_cert_passphrase, gq_cert_passphrase_len);
        if (rc != 0)
            SYS_CONSOLE_PRINT("!!! failed - mbedtls_pk_parse_key(oem_key) - 0x%x\r\n", -rc);
 
        oem_ecp = mbedtls_pk_ec(oem_key);
        rc = mbedtls_mpi_copy(&d, &oem_ecp->d);
        if (rc != 0)
            SYS_CONSOLE_PRINT("!!! mbedtls_mpi_copy returned %d\r\n", rc);
 
        mbedtls_pk_free(&oem_key);
    }
 
    /* DHpublickey */
    /* ContractSignatureEncryptedPrivateKey */
    {
 
        /* Initialize a group of ecdh structures with a SECP256R1 curve. */
        rc = mbedtls_ecp_group_load(&ecdh.grp, MBEDTLS_ECP_DP_SECP256R1);
        if (rc != 0)
            SYS_CONSOLE_PRINT("!!! mbedtls_ecp_group_load returned %d\r\n", rc);
 
        /* Read and apply public keys from other systems in binary data format to ecdh.Qp */
        bytes = res->DHpublickey->CONTENT->bytes;
        bytesLen = res->DHpublickey->CONTENT->bytesLen;
 
        SYS_CONSOLE_PRINT("%s DHpublickey (%x %x %x %x... len %d)\r\n", __func__, bytes[0], bytes[1], bytes[2], bytes[3], bytesLen);
        {
            temp_shared = pvPortMalloc(bytesLen);
            if (temp_shared)
            {
                memcpy(temp_shared, bytes, bytesLen);
                rc = mbedtls_ecp_point_read_binary(&ecdh.grp, &ecdh.Qp, temp_shared, bytesLen);
                //rc = nxp_hse_ecp_point_read_binary(&ecdh.grp, &ecdh.Qp, temp_shared, bytesLen);
                if (rc != 0)
                    SYS_CONSOLE_PRINT("!!! mbedtls_ecp_point_read_binary %d\r\n", rc);
            }
            else
            {
                SYS_CONSOLE_PRINT(LABEL_ISO "!!! memalloc failed -> anyway go\r\n");
                rc = mbedtls_ecp_point_read_binary(&ecdh.grp, &ecdh.Qp, bytes, bytesLen);
                if (rc != 0)
                    SYS_CONSOLE_PRINT("!!! mbedtls_ecp_point_read_binary %d\r\n", rc);
            }
        }
        isoPrintDumpBytes("DHpublickey", bytes, bytesLen);
 
        /* Verify that the d value is a valid private key in SECP256R1 */
        rc = mbedtls_ecp_check_privkey(&ecdh.grp, &d);
        if (rc != 0)
        {
            SYS_CONSOLE_PRINT("Invalid private key: -0x%04X\n", -rc);
        }
 
        /* Verify that the public key is within the valid range of SECP256R1 */
        rc = mbedtls_ecp_check_pubkey(&ecdh.grp, &ecdh.Qp);
        if (rc != 0)
        {
            SYS_CONSOLE_PRINT("DHpublickey is not valid: -0x%04X\n", -rc);
        }
 
 
        /* Calculate the shared secret key, where d is the private key generated in the previous step. */
        rc = mbedtls_ecdh_compute_shared(&ecdh.grp, &z, &ecdh.Qp, &d, myrand, NULL);
        if (rc != 0)
            SYS_CONSOLE_PRINT("!!! mbedtls_ecdh_compute_shared returned %d\r\n", rc);
 
 
        /* Use the shared secret, label, and other info to derive the key */
        rc = mbedtls_ssl_tls_prf(
            MBEDTLS_SSL_TLS_PRF_SHA256,                      /*  Hash function (usually SHA-256 for TLS) */
            &z, //&keyhandle,                     /* Secret data (shared secret) */
            32,                             /* Length of the shared secret */
            "externed master secret", //"extended master secret",   //"master secret",  //"key expansion"
            otherInfo,                   /* Additional data (optional) */
            (int)sizeof(otherInfo),               /* Length of additional data */
            key,                   /* Output buffer for derived key */
            (int)sizeof(key)                /* Desired length of derived key, key handle */
        );
        if (rc != 0)
        {
            SYS_CONSOLE_PRINT("!!! mbedtls_ssl_tls_prf() failed with error -0x%04X\n", -rc);
        }
 
        tmp_rc = mbedtls_aes_setkey_dec(&aes, key, 128);
        if (tmp_rc != 0)
        {
            SYS_CONSOLE_PRINT("!!! mbedtls_aes_setkey_dec returned %d\r\n", tmp_rc);
        }
 
        bytes = res->ContractSignatureEncryptedPrivateKey->CONTENT->bytes;
        bytesLen = res->ContractSignatureEncryptedPrivateKey->CONTENT->bytesLen;
        gq_memcpy(iv, bytes, 16);
        input = bytes + 16;
        bytesLen -= 16u;
 
        {
            uint8_t *temp_input;
            temp_input = pvPortMalloc(bytesLen);
            if (temp_input)
            {
                memcpy(temp_input, input, bytesLen);
                tmp_rc = mbedtls_aes_crypt_cbc(&aes, MBEDTLS_AES_DECRYPT, bytesLen, iv, temp_input, output);
                if (tmp_rc != 0)
                {
                    SYS_CONSOLE_PRINT("!!! mbedtls_aes_crypt_cbc returned %d\r\n", tmp_rc);
                }
                vPortFree(temp_input);
            }
            else
            {
                SYS_CONSOLE_PRINT(LABEL_ISO "!!! mbedtls_aes_crypt_cbc memalloc failed\r\n");
            }
        }
 
        pk_info = mbedtls_pk_info_from_type(MBEDTLS_PK_ECKEY);
        mbedtls_pk_init(&iso->contract_key);
        rc = mbedtls_pk_setup(&iso->contract_key, pk_info);
        if (rc < 0)
        {
            SYS_CONSOLE_MESSAGE("!!! failed-mbedtls_pk_setup\r\n");
        }
 
        ec = mbedtls_pk_ec(iso->contract_key);
        rc = mbedtls_ecp_group_load(&ec->grp, MBEDTLS_ECP_DP_SECP256R1);
        if (rc < 0)
        {
            SYS_CONSOLE_MESSAGE("!!! failed-mbedtls_ecp_group_load\r\n");
        }
 
        isoPrintDumpBytes("PrivateKey", output, bytesLen);
        {
            uint8_t *uds_buf = (uint8_t *)get_gq_uds_buffer();
            memset(uds_buf, 0, 64);
            memcpy(uds_buf+64, output, bytesLen);
 
            no = pki_get_index(KEY_CONTRACT_LEAF);
            if(no < 0)
                pki_add(KEY_CONTRACT_LEAF, uds_buf, bytesLen+64);
            else
                pki_replace(no, KEY_CONTRACT_LEAF, uds_buf, bytesLen+64);
            /* Release the uds buffer */
            put_gq_uds_buffer();
        }
 
        rc = mbedtls_mpi_read_binary(&ec->d, output, bytesLen);
        if (rc < 0)
        {
            SYS_CONSOLE_MESSAGE("!!! failed-mbedtls_mp_read_binary\n");
        }
 
        if (temp_shared != NULL)
        {
            vPortFree(temp_shared);
        }
        mbedtls_mpi_free(&z);
        mbedtls_aes_free(&aes);
        mbedtls_ecdh_free(&ecdh);
    }
 
/* omission */
}
 
createSignature
{
/* omission */
            rc = mbedtls_pk_sign(&iso->contract_key, MBEDTLS_MD_SHA256, hash2, 32, asn, &siglen, mbedtls_ctr_drbg_random,
                                 &ctr_drbg);
       
            if (rc != 0)
            {
                 SYS_CONSOLE_PRINT("mbedtls_pk_sign failed %d\r\n", rc );
            }
 
            /*-----------------------------------------------------------------------------------*/
            /* Signature->SignatureValue 내용 채우기 */
            /*-----------------------------------------------------------------------------------*/
            SignatureValue->Id_isUsed = 0;
            /* SignatureValue->CONTENT 할당 */
            requiredLen = sizeof(struct iso1SignatureValueType_CONTENT);
            retalloc = iso1AllocZCodecEncBuffer(requiredLen);
            if (retalloc != NULL)
            {
                GQ_ISO_MEMCPY(&(SignatureValue->CONTENT), &(retalloc), sizeof(void *));
 
                /* SignatureValue->CONTENT 값 */
                SignatureValue->CONTENT->bytesLen = 64;
                /* MISRA_C_2012_17_07 */
                pasn1 = &asn[4];
            s_index = 37;
            if (asn[3] == 33)
            {
            pasn1++;
            s_index++;
            }
            memcpy(&SignatureValue->CONTENT->bytes[0], pasn1, 32);
 
            pasn1+= 32 + 2;
            if (asn[s_index] == 33)
            pasn1++;
            memcpy(&SignatureValue->CONTENT->bytes[32], pasn1, 32);
 
            }
/* omission */
}
0 项奖励
回复
7,953 次查看
Changhawn
Contributor IV

Dear

About problem, program copy an additional key handler through the key handler and exported it to obtain the key value, and  implemented the program as follow sw. I have two questions.
 
1. When I execute the following, HSE_MY_KeyDeriveCopyKey() returns HSE_SRV_RSP_INVALID_PARAM. Can you tell me what is wrong?
2. Can I obtain the Shared secret (used by DH key exchange protocols) value normally like this?
 
 
static hseSrvResponse_t HSE_KeyDeriveCopyKeyContent
(
    hseKeyHandle_t      targetKeyHandle,
    hseKeyInfo_t        keyInfo,
uint16_t *pPubKeyLength,
uint8_t *pPubKey
)
{
    uint8_t u8MuChannel;
    hseSrvResponse_t srvResponse = -5;
 
    /* Get a free channel on u8MuInstance */
    u8MuChannel = Hse_Ip_GetFreeChannel(APP_MU_INSTANCE_U8);
    if(HSE_IP_INVALID_MU_CHANNEL_U8 == u8MuChannel)
    {
    goto exit;
    }
 
/*note: which MU channel need to specify?*/
    hseSrvDescriptor_t *pHseSrvDesc = &Hse_aSrvDescriptor[u8MuChannel];
    hseExportKeySrv_t*  pExportKeyReq = &pHseSrvDesc->hseSrv.exportKeyReq;
    memset(pHseSrvDesc, 0, sizeof(hseSrvDescriptor_t));
    pHseSrvDesc->srvId = HSE_SRV_ID_EXPORT_KEY;
    pExportKeyReq->targetKeyHandle = targetKeyHandle;
 
    pExportKeyReq->pKey[0] = (HOST_ADDR)pPubKey;
    pExportKeyReq->pKeyLen[0] = (HOST_ADDR)pPubKeyLength;
 
    pExportKeyReq->cipher.cipherKeyHandle = HSE_INVALID_KEY_HANDLE;
    pExportKeyReq->keyContainer.authKeyHandle = HSE_INVALID_KEY_HANDLE;
 
/* Build the request to be sent to Hse Ip layer */
    HseIp_aRequest[u8MuChannel].eReqType   = HSE_IP_REQTYPE_SYNC;
    HseIp_aRequest[u8MuChannel].u32Timeout = TIMEOUT_TICKS_U32;
 
    /*note: which MU channel need to specify?*/
    srvResponse = Hse_Ip_ServiceRequest(APP_MU_INSTANCE_U8, u8MuChannel, &HseIp_aRequest[u8MuChannel], pHseSrvDesc);
 
exit:
 
    return srvResponse;
}
 
hseSrvResponse_t HSE_MY_KeyDeriveCopyKey
(
    hseKeyHandle_t      keyHandle,
    uint16_t            startOffset,
    hseKeyHandle_t      targetKeyHandle,
    hseKeyInfo_t        keyInfo
)
{
    uint8_t u8MuChannel;
    hseSrvResponse_t srvResponse = HSE_SRV_RSP_GENERAL_ERROR;
 
    /* Get a free channel on u8MuInstance */
    u8MuChannel = Hse_Ip_GetFreeChannel(APP_MU_INSTANCE_U8);
    if(HSE_IP_INVALID_MU_CHANNEL_U8 == u8MuChannel)
    {
    goto exit;
    }
 
/*note: which MU channel need to specify?*/
    hseSrvDescriptor_t *pHseSrvDesc = &Hse_aSrvDescriptor[u8MuChannel];
 
    hseKeyDeriveCopyKeySrv_t *pExtractKeySrv = &(pHseSrvDesc->hseSrv.keyDeriveCopyKeyReq);
 
    memset(pHseSrvDesc, 0, sizeof(hseSrvDescriptor_t));
    pHseSrvDesc->srvId = HSE_SRV_ID_KEY_DERIVE_COPY;
 
    pExtractKeySrv->keyHandle = keyHandle;
    pExtractKeySrv->startOffset = startOffset;
    pExtractKeySrv->targetKeyHandle = targetKeyHandle;
    pExtractKeySrv->keyInfo = keyInfo;
 
/* Build the request to be sent to Hse Ip layer */
    HseIp_aRequest[u8MuChannel].eReqType   = HSE_IP_REQTYPE_SYNC;
    HseIp_aRequest[u8MuChannel].u32Timeout = TIMEOUT_TICKS_U32;
 
    /*note: which MU channel need to specify?*/
    srvResponse = Hse_Ip_ServiceRequest(APP_MU_INSTANCE_U8, u8MuChannel, &HseIp_aRequest[u8MuChannel], pHseSrvDesc);
 
exit:
    return srvResponse;
}
 
int32_t gq_getComputeSharedKey(uint32_t keyHandle, uint8_t *keyBuf)
{
    /* uint8_t keyBuf[32]; */
    uint16_t keyBufLen = 32; 
hseKeyInfo_t KeyInfo;
hseSrvResponse_t srvResponse;
int32_t ret = 0;
uint32_t copykeyslot = HSE_INVALID_KEY_HANDLE;
/* uint8_t export_key[32]={ 0, }; */
 
key_import_param_t key_import_param_shared;
 
memset(&key_import_param_shared, 0x00, sizeof(key_import_param_t));
 
/* copy shared secret key */
key_import_param_shared.key_type = HSE_KEY_TYPE_SHARED_SECRET;
key_import_param_shared.key_catalog = HSE_KEY_CATALOG_ID_RAM;
key_import_param_shared.key_param.sym_key_param.size = 256u;
 
KeystoreMgmt_FindAllocateSlot(&key_import_param_shared, &copykeyslot);
 
memset(keyBuf, 0, keyBufLen);
 
srvResponse = HSE_GetKeyInfo(keyHandle, &KeyInfo);
if(srvResponse == HSE_SRV_RSP_OK)
{
KeyInfo.keyFlags = (HSE_KF_USAGE_ENCRYPT | HSE_KF_USAGE_DECRYPT | HSE_KF_USAGE_SIGN | HSE_KF_USAGE_VERIFY | HSE_KF_USAGE_DERIVE);
KeyInfo.keyType = HSE_KEY_TYPE_SHARED_SECRET;
 
printf("copykeyslot=0x%08x\n", copykeyslot);
/* copykeyslot = 0x00020601; */
srvResponse = HSE_MY_KeyDeriveCopyKey(keyHandle, 0, copykeyslot, KeyInfo);
if(srvResponse != HSE_SRV_RSP_OK)
{
ret = srvResponse;
}
else
{
printf("HSE_KeyDeriveCopyKey() is ok\r\n");
srvResponse = HSE_KeyDeriveCopyKeyContent(copykeyslot, KeyInfo, &keyBufLen, keyBuf);
if(srvResponse != HSE_SRV_RSP_OK)
{
ret = srvResponse;
}
else
{
printf("HSE_KeyDeriveCopyKeyContent() is ok\r\n");
}
}
}
else
{
ret = -2;
}
 
return ret;
}
0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-1993308%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%85%B3%E4%BA%8ES32K314%E4%B8%8EHSE%E7%9A%84TLS%20API%E7%9A%84%E9%97%AE%E9%A2%98%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1993308%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%9C%A8S32K314%E4%B8%AD%EF%BC%8C%3CBR%20%2F%3E%E6%88%91%E4%BB%AC%E6%AD%A3%E5%9C%A8%E4%BD%BF%E7%94%A8%20NXP%20%E6%8F%90%E4%BE%9B%E7%9A%84%E5%B8%A6%E6%9C%89%20HSE%20%E7%9A%84%20Mbedtls%20RTM%201.0.0%E3%80%82%3C%2FP%3E%3CP%3ETLS%20%E6%8F%A1%E6%89%8B%E4%B9%8B%E5%90%8E%EF%BC%8C%E6%88%91%E4%BB%AC%E9%9C%80%E8%A6%81%E8%AE%A1%E7%AE%97%E5%85%B1%E4%BA%AB%E5%AF%86%E9%92%A5%EF%BC%8C%E5%9B%A0%E6%AD%A4%E6%88%91%E4%BB%AC%E4%BD%BF%E7%94%A8%20mbedtls_ecdh_compute_shared()%20API%EF%BC%8C%3C%2FP%3E%3CP%3E%E4%BD%86%E6%98%AF%E8%AF%A5%20API%EF%BC%88mbedtls_ecdh_compute_shared%EF%BC%89%E5%B0%86%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%E5%88%86%E9%85%8D%E4%B8%BA%20z%20%E5%80%BC%E5%8F%82%E6%95%B0%EF%BC%8C%E5%A6%82%E4%B8%8B%E5%9B%BE%E6%89%80%E7%A4%BA%E3%80%82%3C%2FP%3E%3CP%3E%E5%9C%A8%E5%AE%9E%E9%99%85%E6%93%8D%E4%BD%9C%E4%B8%AD%EF%BC%8C%E6%88%91%E4%BB%AC%E9%9C%80%E8%A6%81%E5%AF%BC%E5%87%BA%E5%AE%9E%E9%99%85%E7%9A%84%E5%85%B1%E4%BA%AB%E5%AF%86%E9%92%A5%E5%80%BC%EF%BC%8C%E8%80%8C%E4%B8%8D%E6%98%AF%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%E5%80%BC%E3%80%82%E6%88%91%E4%BB%AC%E6%80%8E%E6%A0%B7%E6%89%8D%E8%83%BD%E5%81%9A%E5%88%B0%E8%BF%99%E4%B8%80%E7%82%B9%EF%BC%9F%E8%AF%B7%E6%8C%87%E5%AF%BC%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3CP%3ETLS%20%E4%BB%A3%E7%A0%81)%3C%2FP%3E%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%20lia-image-align-inline%22%20image-alt%3D%22Changhawn_0-1731469557649.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22Changhawn_0-1731469557649.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F310183i3E6EACE63E1E93CF%2Fimage-size%2Fmedium%3Fv%3Dv2%26amp%3Bpx%3D400%22%20role%3D%22button%22%20title%3D%22Changhawn_0-1731469557649.png%22%20alt%3D%22Changhawn_0-1731469557649.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%E5%BA%94%E7%94%A8%E7%A8%8B%E5%BA%8F%E4%BB%A3%E7%A0%81%EF%BC%89%3C%2FP%3E%3CDIV%3Euint8_t%20sharedSecret%5B32%5D%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E~~~%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecdh_compute_shared%EF%BC%88%26amp%3Becdh.grp%EF%BC%8C%26amp%3Bz%2C%20%26amp%3Becdh.Qp%2C%20%26amp%3Bd%2C%20myrand%2C%20NULL)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_ecdh_compute_shared%20%E8%BF%94%E5%9B%9E%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Etmp_rc%20%3D%20mbedtls_mpi_write_binary%EF%BC%88%EF%BC%86z%EF%BC%8C%E5%85%B1%E4%BA%AB%E5%AF%86%E9%92%A5%EF%BC%8C32%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88tmp_rc%EF%BC%81%3D%200%EF%BC%89%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_mpi_write_binary%20%E8%BF%94%E5%9B%9E%20%25d%5Cr%5Cn%22%2C%20tmp_rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EPrintDumpBytes(%22sharedSecret%22%2C%20sharedSecret%2C%2032)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CP%3E%E6%B5%8B%E8%AF%95%E6%97%A5%E5%BF%97%EF%BC%89%3C%2FP%3E%3CP%3E%E7%A7%81%E9%92%A5%E5%8F%A5%E6%9F%84%200x20400%20%7C%20%E5%AF%B9%E7%AD%89%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%20%3A%200x20500%20%7C%20%E5%85%B1%E4%BA%AB%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%200x20600%3CBR%20%2F%3E%20Z%20%E6%98%AF%2020600%3CBR%20%2F%3E%E5%85%B1%E4%BA%AB%E7%A7%98%E5%AF%86%3D%3CBR%20%2F%3E%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2000%2002%2006%2000%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2007786%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E5%85%B3%E4%BA%8E%E4%BD%BF%E7%94%A8%20HSE%20%E7%9A%84%20TLS%20API%20%E7%9A%84%20S32K314%20%E9%97%AE%E9%A2%98%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2007786%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BA%B2%E7%88%B1%E7%9A%84%E6%81%A9%E6%99%BA%E6%B5%A6%E6%9C%8B%E5%8F%8B%E4%BB%AC%E3%80%82%3C%2FP%3E%3CP%3E%E5%9C%A8%20KDF%20%E4%B8%AD%EF%BC%8C%E6%88%91%E7%9F%A5%E9%81%93%20NXP%20HSE%20%E7%9B%AE%E5%89%8D%E4%B8%8D%E6%94%AF%E6%8C%81%20NIST%20800-56A%E3%80%82%3C%2FP%3E%3CP%3E%E5%9B%A0%E6%AD%A4%EF%BC%8C%E5%9C%A8%E6%B2%A1%E6%9C%89%20HSE%20%E7%9A%84%E6%83%85%E5%86%B5%E4%B8%8B%E5%AE%9E%E6%96%BD%E4%BA%86%E8%AF%A5%E6%8E%AA%E6%96%BD%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1995790%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E5%85%B3%E4%BA%8E%E4%BD%BF%E7%94%A8%20HSE%20%E7%9A%84%20TLS%20API%20%E7%9A%84%20S32K314%20%E9%97%AE%E9%A2%98%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1995790%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CDIV%3E%E4%B8%8B%E9%9D%A2%E6%98%AF%E5%9C%A8%E8%BF%90%E8%A1%8C%20HSE%20%E7%9A%84%E5%B9%B3%E5%8F%B0%E4%B8%8A%E7%BC%96%E5%86%99%E7%9A%84%E4%BB%A3%E7%A0%81%EF%BC%8C%E5%8D%B3%E5%90%AF%E7%94%A8%20MBEDTLS_USE_NXP_HSE_CRYPTO%EF%BC%8C%E5%AE%8C%E6%88%90%20tls%20%E6%8F%A1%E6%89%8B%E5%A4%84%E7%90%86%E5%90%8E%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%8C%85%E6%8B%AC%E4%BD%BF%E7%94%A8%E8%AF%81%E4%B9%A6%E5%92%8CDH%E5%85%AC%E9%92%A5%E7%94%9F%E6%88%90%E6%B4%BE%E7%94%9F%E5%AF%86%E9%92%A5%EF%BC%8C%E9%80%9A%E8%BF%87AES%E8%A7%A3%E5%AF%86%E7%A7%81%E9%92%A5%E5%B9%B6%E8%B5%8B%E5%80%BC%E7%BB%99ECC%E4%B8%8A%E4%B8%8B%E6%96%87%E7%9A%84%E8%BF%87%E7%A8%8B%EF%BC%8C%E4%BB%A5%E5%8F%8A%E7%AD%BE%E5%90%8D%E7%94%9F%E6%88%90%E8%BF%87%E7%A8%8B%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%8D%B3%E4%BD%BF%E7%94%A8%E8%AF%81%E4%B9%A6%E5%92%8CDH%E5%85%AC%E9%92%A5%E5%88%9B%E5%BB%BA%E5%8A%A0%E5%AF%86%E5%AF%86%E9%92%A5%EF%BC%8C%E5%B9%B6%E4%BD%BF%E7%94%A8mbedtls_ssl_tls_prf()%E6%B4%BE%E7%94%9F%E8%AF%A5%E5%AF%86%E9%92%A5%EF%BC%8C%E7%84%B6%E5%90%8E%E9%80%9A%E8%BF%87AES%E5%88%9B%E5%BB%BA%E7%A7%81%E9%92%A5%EF%BC%88%E8%BE%93%E5%87%BA%EF%BC%89%E5%B9%B6%E5%88%86%E9%85%8D%E7%BB%99ECC%E4%B8%8A%E4%B8%8B%E6%96%87%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E4%BD%86%E6%98%AF%E5%9C%A8%E6%8E%88%E6%9D%83%E8%AF%B7%E6%B1%82%E8%BF%87%E7%A8%8B%E4%B8%AD%EF%BC%8C%E5%88%9B%E5%BB%BA%E7%9A%84SignatureValue%E5%9C%A8%E6%8E%88%E6%9D%83%E8%AF%B7%E6%B1%82%E4%B8%AD%E5%93%8D%E5%BA%94%E4%BA%86%E4%B8%80%E4%B8%AA%E9%94%99%E8%AF%AF%E7%9A%84%E7%AD%BE%E5%90%8D%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSTRONG%3E1.%E5%AF%B9%E4%BA%8E%E5%AF%86%E9%92%A5%E6%B4%BE%E7%94%9F%EF%BC%8C%E4%BD%BF%E7%94%A8%20mbedtls_ssl_tls_prf()%EF%BC%8C%E6%A0%87%E7%AD%BE%E6%98%AF%E5%90%A6%E6%AD%A3%E7%A1%AE%EF%BC%9F%E6%88%96%E4%B8%8D%EF%BC%9F%3C%2FSTRONG%3E%3C%2FDIV%3E%3CDIV%3E%E5%93%AA%E4%B8%80%E4%B8%AA%E6%98%AF%E2%80%9C%E5%A4%96%E9%83%A8%E4%B8%BB%E7%A7%98%E5%AF%86%E2%80%9D%E6%88%96%E2%80%9C%E5%AF%86%E9%92%A5%E6%89%A9%E5%B1%95%E2%80%9D%EF%BC%9F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSTRONG%3E2.%20%E4%B8%8B%E9%9D%A2%E7%9A%84%E4%BB%A3%E7%A0%81%E6%9C%89%E4%BB%80%E4%B9%88%E9%94%99%E8%AF%AF%E5%90%97%EF%BC%9F%3C%2FSTRONG%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E8%AE%A4%E8%AF%81%E5%AE%89%E8%A3%85%E5%93%8D%E5%BA%94%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E7%9C%81%E7%95%A5%20*%2F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%7B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20mbedtls_pk_context%20oem_key%3B%3C%2FDIV%3E%3CDIV%3Embedtls_ecp_keypair%20*oem_ecp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Embedtls_pk_init%EF%BC%88%26amp%3Boem_key%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3Embedtls_mpi_init%EF%BC%88%26amp%3Bd%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20rc%20%3D%20mbedtls_pk_parse_key(%26amp%3Boem_key%2C%20PKI_1_CRT_OEM_LEAF_VALID_key%2C%20PKI_1_CRT_OEM_LEAF_VALID_key_len%2C%3C%2FDIV%3E%3CDIV%3Egq_cert_passphrase%EF%BC%8Cgq_cert_passphrase_len%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20%E5%A4%B1%E8%B4%A5%20-%20mbedtls_pk_parse_key(oem_key)%20-%200x%25x%5Cr%5Cn%22%2C%20-rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Eoem_ecp%20%3D%20mbedtls_pk_ec(oem_key)%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_mpi_copy%EF%BC%88%26amp%3Bd%EF%BC%8C%26amp%3Boem_ecp-%26gt%3Bd%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_mpi_copy%20%E8%BF%94%E5%9B%9E%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Embedtls_pk_free%EF%BC%88%26amp%3Boem_key%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%2F*%20DHpublickey%20*%2F%3C%2FDIV%3E%3CDIV%3E%2F*%20%E5%90%88%E5%90%8C%E7%AD%BE%E5%90%8D%E5%8A%A0%E5%AF%86%E7%A7%81%E9%92%A5%20*%2F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%7B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E7%94%A8SECP256R1%E6%9B%B2%E7%BA%BF%E5%88%9D%E5%A7%8B%E5%8C%96%E4%B8%80%E7%BB%84ecdh%E7%BB%93%E6%9E%84%E3%80%82*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_group_load%EF%BC%88%26amp%3Becdh.grp%EF%BC%8CMBEDTLS_ECP_DP_SECP256R1%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_ecp_group_load%20%E8%BF%94%E5%9B%9E%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E4%BB%8E%E5%85%B6%E4%BB%96%E7%B3%BB%E7%BB%9F%E8%AF%BB%E5%8F%96%E4%BA%8C%E8%BF%9B%E5%88%B6%E6%95%B0%E6%8D%AE%E6%A0%BC%E5%BC%8F%E7%9A%84%E5%85%AC%E9%92%A5%E5%B9%B6%E5%B0%86%E5%85%B6%E5%BA%94%E7%94%A8%E5%88%B0%20ecdh.Qp%20*%2F%3C%2FDIV%3E%3CDIV%3E%E5%AD%97%E8%8A%82%20%3D%20res-%26gt%3BDHpublickey-%26gt%3BCONTENT-%26gt%3B%E5%AD%97%E8%8A%82%EF%BC%9B%3C%2FDIV%3E%3CDIV%3EbytesLen%20%3D%20res-%26gt%3BDHpublickey-%26gt%3BCONTENT-%26gt%3BbytesLen%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22%25s%20DHpublickey%20(%25x%20%25x%20%25x%20%25x...%20%E9%95%BF%E5%BA%A6%20%25d)%5Cr%5Cn%22%2C%20__func__%20%2C%20bytes%5B0%5D%2C%20bytes%5B1%5D%2C%20bytes%5B2%5D%2C%20bytes%5B3%5D%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3Etemp_shared%20%3D%20pvPortMalloc(bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88temp_shared%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3Ememcpy%EF%BC%88temp_shared%EF%BC%8C%E5%AD%97%E8%8A%82%EF%BC%8CbytesLen%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_point_read_binary%EF%BC%88%26amp%3Becdh.grp%EF%BC%8C%26amp%3Becdh.Qp%EF%BC%8Ctemp_shared%EF%BC%8CbytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%2F%2Frc%20%3D%20nxp_hse_ecp_point_read_binary%EF%BC%88%26amp%3Becdh.grp%EF%BC%8C%26amp%3Becdh.Qp%EF%BC%8Ctemp_shared%EF%BC%8CbytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_ecp_point_read_binary%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20else%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(LABEL_ISO%20%22!!!%20memalloc%20%E5%A4%B1%E8%B4%A5%20-%26gt%3B%20%E6%97%A0%E8%AE%BA%E5%A6%82%E4%BD%95%5Cr%5Cn%22)%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_point_read_binary%EF%BC%88%26amp%3Becdh.grp%EF%BC%8C%26amp%3Becdh.Qp%EF%BC%8C%E5%AD%97%E8%8A%82%EF%BC%8CbytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_ecp_point_read_binary%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3EisoPrintDumpBytes(%22DHpublickey%22%2C%20%E5%AD%97%E8%8A%82%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E9%AA%8C%E8%AF%81%20d%20%E5%80%BC%E6%98%AF%E5%90%A6%E4%B8%BA%20SECP256R1%20%E4%B8%AD%E7%9A%84%E6%9C%89%E6%95%88%E7%A7%81%E9%92%A5%20*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_check_privkey%EF%BC%88%26amp%3Becdh.grp%EF%BC%8C%26amp%3Bd)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22%E6%97%A0%E6%95%88%E7%A7%81%E9%92%A5%EF%BC%9A-0x%2504X%5Cn%22%2C%20-rc)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E9%AA%8C%E8%AF%81%E5%85%AC%E9%92%A5%E6%98%AF%E5%90%A6%E5%9C%A8SECP256R1%E7%9A%84%E6%9C%89%E6%95%88%E8%8C%83%E5%9B%B4%E5%86%85%20*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_check_pubkey%EF%BC%88%26amp%3Becdh.grp%EF%BC%8C%26amp%3Becdh.Qp)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22DHpublickey%20%E6%97%A0%E6%95%88%EF%BC%9A-0x%2504X%5Cn%22%2C%20-rc)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E8%AE%A1%E7%AE%97%E5%85%B1%E4%BA%AB%E5%AF%86%E9%92%A5%EF%BC%8C%E5%85%B6%E4%B8%ADd%E6%98%AF%E4%B8%8A%E4%B8%80%E6%AD%A5%E7%94%9F%E6%88%90%E7%9A%84%E7%A7%81%E9%92%A5%E3%80%82*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecdh_compute_shared%EF%BC%88%26amp%3Becdh.grp%EF%BC%8C%26amp%3Bz%2C%20%26amp%3Becdh.Qp%2C%20%26amp%3Bd%2C%20myrand%2C%20NULL)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_ecdh_compute_shared%20%E8%BF%94%E5%9B%9E%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E4%BD%BF%E7%94%A8%E5%85%B1%E4%BA%AB%E7%A7%98%E5%AF%86%E3%80%81%E6%A0%87%E7%AD%BE%E5%92%8C%E5%85%B6%E4%BB%96%E4%BF%A1%E6%81%AF%E6%9D%A5%E6%B4%BE%E7%94%9F%E5%AF%86%E9%92%A5%20*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ssl_tls_prf%EF%BC%88%3C%2FDIV%3E%3CDIV%3EMBEDTLS_SSL_TLS_PRF_SHA256%EF%BC%8C%2F*%20%E5%93%88%E5%B8%8C%E5%87%BD%E6%95%B0%EF%BC%88%E5%AF%B9%E4%BA%8E%20TLS%20%E9%80%9A%E5%B8%B8%E4%B8%BA%20SHA-256%EF%BC%89*%2F%3C%2FDIV%3E%3CDIV%3E%26amp%3Bz%2C%20%2F%2F%26amp%3Bkeyhandle%2C%20%2F*%20%E7%A7%98%E5%AF%86%E6%95%B0%E6%8D%AE%EF%BC%88%E5%85%B1%E4%BA%AB%E7%A7%98%E5%AF%86%EF%BC%89%20*%2F%3C%2FDIV%3E%3CDIV%3E32%EF%BC%8C%2F*%E5%85%B1%E4%BA%AB%E7%A7%98%E5%AF%86%E7%9A%84%E9%95%BF%E5%BA%A6*%2F%3C%2FDIV%3E%3CDIV%3E%E2%80%9C%E5%A4%96%E9%83%A8%E4%B8%BB%E5%AF%86%E9%92%A5%E2%80%9D%EF%BC%8C%2F%2F%E2%80%9C%E6%89%A9%E5%B1%95%E4%B8%BB%E5%AF%86%E9%92%A5%E2%80%9D%EF%BC%8C%2F%2F%E2%80%9C%E4%B8%BB%E5%AF%86%E9%92%A5%E2%80%9D%EF%BC%8C%2F%2F%E2%80%9C%E5%AF%86%E9%92%A5%E6%89%A9%E5%B1%95%E2%80%9D%3C%2FDIV%3E%3CDIV%3EotherInfo%2C%2F*%20%E9%99%84%E5%8A%A0%E6%95%B0%E6%8D%AE%EF%BC%88%E5%8F%AF%E9%80%89%EF%BC%89*%2F%3C%2FDIV%3E%3CDIV%3E(int)sizeof(otherInfo)%2C%20%2F*%20%E9%99%84%E5%8A%A0%E6%95%B0%E6%8D%AE%E7%9A%84%E9%95%BF%E5%BA%A6%20*%2F%3C%2FDIV%3E%3CDIV%3Ekey%2C%20%2F*%20%E6%B4%BE%E7%94%9F%E5%AF%86%E9%92%A5%E7%9A%84%E8%BE%93%E5%87%BA%E7%BC%93%E5%86%B2%E5%8C%BA%20*%2F%3C%2FDIV%3E%3CDIV%3E(int)sizeof(key)%20%2F*%20%E6%B4%BE%E7%94%9F%E5%AF%86%E9%92%A5%E7%9A%84%E6%89%80%E9%9C%80%E9%95%BF%E5%BA%A6%E3%80%81%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%20*%2F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_ssl_tls_prf()%20%E5%A4%B1%E8%B4%A5%EF%BC%8C%E9%94%99%E8%AF%AF%E4%B8%BA%20-0x%2504X%5Cn%22%2C%20-rc)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20tmp_rc%20%3D%20mbedtls_aes_setkey_dec(%26amp%3Baes%2C%20key%2C%20128)%3B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88tmp_rc%EF%BC%81%3D%200%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_aes_setkey_dec%20%E8%BF%94%E5%9B%9E%20%25d%5Cr%5Cn%22%2C%20tmp_rc)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%AD%97%E8%8A%82%20%3D%20res-%26gt%3BContractSignatureEncryptedPrivateKey-%26gt%3B%E5%86%85%E5%AE%B9-%26gt%3B%E5%AD%97%E8%8A%82%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20bytesLen%20%3D%20res-%26gt%3BContractSignatureEncryptedPrivateKey-%26gt%3BCONTENT-%26gt%3BbytesLen%3B%3C%2FDIV%3E%3CDIV%3Egq_memcpy%EF%BC%88iv%EF%BC%8C%E5%AD%97%E8%8A%82%EF%BC%8C16%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%E8%BE%93%E5%85%A5%3D%E5%AD%97%E8%8A%82%2B16%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20bytesLen%20-%3D%2016u%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20uint8_t%20*temp_input%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20temp_input%20%3D%20pvPortMalloc(bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88temp_input%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20memcpy(temp_input%2C%20input%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20tmp_rc%20%3D%20mbedtls_aes_crypt_cbc(%26amp%3Baes%2C%20MBEDTLS_AES_DECRYPT%2C%20bytesLen%2C%20iv%2C%20temp_input%2C%20output)%3B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88tmp_rc%EF%BC%81%3D%200%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!!%20mbedtls_aes_crypt_cbc%20%E8%BF%94%E5%9B%9E%20%25d%5Cr%5Cn%22%2C%20tmp_rc)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20vPortFree(temp_input)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20else%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(LABEL_ISO%20%22!!!%20mbedtls_aes_crypt_cbc%20memalloc%20%E5%A4%B1%E8%B4%A5%5Cr%5Cn%22)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Epk_info%20%3D%20mbedtls_pk_info_from_type(MBEDTLS_PK_ECKEY)%3B%3C%2FDIV%3E%3CDIV%3Embedtls_pk_init%EF%BC%88%26amp%3Biso-%26gt%3Bcontract_key%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_pk_setup%EF%BC%88%26amp%3Biso-%26gt%3Bcontract_key%EF%BC%8Cpk_info%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20%26lt%3B%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_MESSAGE(%E2%80%9C!!!%E5%A4%B1%E8%B4%A5-mbedtls_pk_setup%5Cr%5Cn%E2%80%9D)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20ec%20%3D%20mbedtls_pk_ec(iso-%26gt%3Bcontract_key)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20rc%20%3D%20mbedtls_ecp_group_load(%26amp%3Bec-%26gt%3Bgrp%2C%20MBEDTLS_ECP_DP_SECP256R1)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20%26lt%3B%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_MESSAGE(%E2%80%9C!!!%E5%A4%B1%E8%B4%A5-mbedtls_ecp_group_load%5Cr%5Cn%E2%80%9D)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EisoPrintDumpBytes(%22%E7%A7%81%E9%92%A5%22%2C%20%E8%BE%93%E5%87%BA%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20uint8_t%20*uds_buf%20%3D%20(uint8_t%20*)get_gq_uds_buffer()%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20memset(uds_buf%2C%200%2C%2064)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20memcpy(uds_buf%2B64%2C%20output%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%90%A6%20%3D%20pki_get_index(KEY_CONTRACT_LEAF)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if(no%20%26lt%3B%200)%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20pki_add(KEY_CONTRACT_LEAF%2C%20uds_buf%2C%20bytesLen%2B64)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20else%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20pki_replace(no%2C%20KEY_CONTRACT_LEAF%2C%20uds_buf%2C%20bytesLen%2B64)%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E9%87%8A%E6%94%BEuds%E7%BC%93%E5%86%B2%E5%8C%BA%20*%2F%3C%2FDIV%3E%3CDIV%3E%E6%94%BE%E5%85%A5%20gq_uds_buffer()%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_mpi_read_binary(%26amp%3Bec-%26gt%3Bd%2C%20%E8%BE%93%E5%87%BA%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20%26lt%3B%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_MESSAGE(%E2%80%9C!!!%E5%A4%B1%E8%B4%A5-mbedtls_mp_read_binary%5Cn%E2%80%9D)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88temp_shared%EF%BC%81%3D%20NULL%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3EvPortFree%EF%BC%88temp_shared%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3Embedtls_mpi_free%EF%BC%88%26amp%3Bz%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20mbedtls_aes_free(%26amp%3Baes)%3B%3C%2FDIV%3E%3CDIV%3Embedtls_ecdh_free%EF%BC%88%26amp%3Becdh%EF%BC%89%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E7%9C%81%E7%95%A5%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%88%9B%E5%BB%BA%E7%AD%BE%E5%90%8D%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E7%9C%81%E7%95%A5%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_pk_sign%EF%BC%88%26amp%3Biso-%26gt%3Bcontract_key%EF%BC%8CMBEDTLS_MD_SHA256%EF%BC%8Chash2%EF%BC%8C32%EF%BC%8Casn%EF%BC%8C%26amp%3Bsiglen%EF%BC%8Cmbedtls_ctr_drbg_random%EF%BC%8C%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%26amp%3Bctr_drbg)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22mbedtls_pk_sign%20%E5%A4%B1%E8%B4%A5%20%25d%5Cr%5Cn%22%2C%20rc%20)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%2F*-----------------------------------------------------------------------------------*%2F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%2F*%20Signature-%26gt%3BSignatureValue%20%EB%82%B4%EC%9A%A9%20%EC%B1%84%EC%9A%B0%EA%B8%B0%20*%2F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%2F*-----------------------------------------------------------------------------------*%2F%3C%2FDIV%3E%3CDIV%3ESignatureValue-%26gt%3BId_isUsed%20%3D%200%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20SignatureValue-%26gt%3BCONTENT%20%ED%95%A0%EB%8B%B9%20*%2F%3C%2FDIV%3E%3CDIV%3ErequiredLen%20%3D%20sizeof(%E7%BB%93%E6%9E%84%20iso1SignatureValueType_CONTENT)%3B%3C%2FDIV%3E%3CDIV%3Eretalloc%20%3D%20iso1AllocZCodecEncBuffer(requiredLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20if%20(retalloc%20!%3D%20NULL)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3EGQ_ISO_MEMCPY(%26amp%3B(SignatureValue-%26gt%3BCONTENT)%2C%20%26amp%3B(retalloc)%2C%20sizeof(void%20*))%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20SignatureValue-%26gt%3BCONTENT%20%EA%B0%92%20*%2F%3C%2FDIV%3E%3CDIV%3E%E7%AD%BE%E5%90%8D%E5%80%BC-%26gt%3B%E5%86%85%E5%AE%B9-%26gt%3BbytesLen%20%3D%2064%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%2F*%20MISRA_C_2012_17_07%20*%2F%3C%2FDIV%3E%3CDIV%3Epasn1%20%3D%20%26amp%3Basn%5B4%5D%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20s_index%20%3D%2037%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%20(asn%5B3%5D%20%3D%3D%2033)%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20pasn1%2B%2B%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20s_index%2B%2B%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%20%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ememcpy(%26amp%3BSignatureValue-%26gt%3BCONTENT-%26gt%3Bbytes%5B0%5D%2C%20pasn1%2C%2032)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20pasn1%2B%3D%2032%20%2B%202%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%EF%BC%88asn%20%5Bs_index%5D%20%3D%3D%2033%EF%BC%89%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20pasn1%2B%2B%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ememcpy(%26amp%3BSignatureValue-%26gt%3BCONTENT-%26gt%3Bbytes%5B32%5D%2C%20pasn1%2C%2032)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E7%9C%81%E7%95%A5%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1994187%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E5%85%B3%E4%BA%8E%E4%BD%BF%E7%94%A8%20HSE%20%E7%9A%84%20TLS%20API%20%E7%9A%84%20S32K314%20%E9%97%AE%E9%A2%98%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1994187%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%B0%8A%E6%95%AC%E7%9A%84%3C%2FP%3E%3CDIV%3E%E5%85%B3%E4%BA%8E%E9%97%AE%E9%A2%98%EF%BC%8C%E7%A8%8B%E5%BA%8F%E9%80%9A%E8%BF%87%E5%AF%86%E9%92%A5%E5%A4%84%E7%90%86%E7%A8%8B%E5%BA%8F%E5%A4%8D%E5%88%B6%E4%B8%80%E4%B8%AA%E9%A2%9D%E5%A4%96%E7%9A%84%E5%AF%86%E9%92%A5%E5%A4%84%E7%90%86%E7%A8%8B%E5%BA%8F%E5%B9%B6%E5%B0%86%E5%85%B6%E5%AF%BC%E5%87%BA%E4%BB%A5%E8%8E%B7%E5%8F%96%E5%AF%86%E9%92%A5%E5%80%BC%EF%BC%8C%E5%B9%B6%E6%8C%89%E7%85%A7%E5%A6%82%E4%B8%8Bsw%E5%AE%9E%E7%8E%B0%E7%A8%8B%E5%BA%8F%E3%80%82%E6%88%91%E6%9C%89%E4%B8%A4%E4%B8%AA%E9%97%AE%E9%A2%98%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E1.%E5%BD%93%E6%88%91%E6%89%A7%E8%A1%8C%E4%BB%A5%E4%B8%8B%E6%93%8D%E4%BD%9C%E6%97%B6%EF%BC%8CHSE_MY_KeyDeriveCopyKey()%20%E8%BF%94%E5%9B%9E%20HSE_SRV_RSP_INVALID_PARAM%E3%80%82%E6%82%A8%E8%83%BD%E5%91%8A%E8%AF%89%E6%88%91%E5%93%AA%E9%87%8C%E5%87%BA%E4%BA%86%E9%97%AE%E9%A2%98%E5%90%97%EF%BC%9F%3C%2FDIV%3E%3CDIV%3E2.%20%E6%88%91%E5%8F%AF%E4%BB%A5%E5%83%8F%E8%BF%99%E6%A0%B7%E6%AD%A3%E5%B8%B8%E8%8E%B7%E5%8F%96%E5%85%B1%E4%BA%AB%E7%A7%98%E5%AF%86%EF%BC%88DH%20%E5%AF%86%E9%92%A5%E4%BA%A4%E6%8D%A2%E5%8D%8F%E8%AE%AE%E4%BD%BF%E7%94%A8%EF%BC%89%E5%80%BC%E5%90%97%EF%BC%9F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E9%9D%99%E6%80%81%20hseSrvResponse_t%20HSE_KeyDeriveCopyKeyContent%3C%2FDIV%3E%3CDIV%3E(%3C%2FDIV%3E%3CDIV%3EhseKeyHandle_t%20%E7%9B%AE%E6%A0%87%E9%94%AE%E5%8F%A5%E6%9F%84%EF%BC%8C%3C%2FDIV%3E%3CDIV%3EhseKeyInfo_t%20%E5%AF%86%E9%92%A5%E4%BF%A1%E6%81%AF%EF%BC%8C%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Euint16_t%20*pPubKeyLength%EF%BC%8C%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Euint8_t%20*pPubKey%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3Euint8_t%20u8MuChannel%EF%BC%9B%3C%2FDIV%3E%3CDIV%3EhseSrvResponse_t%20srvResponse%20%3D%20-5%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E5%9C%A8%20u8MuInstance%20%E4%B8%8A%E8%8E%B7%E5%8F%96%E5%85%8D%E8%B4%B9%E9%A2%91%E9%81%93%20*%2F%3C%2FDIV%3E%3CDIV%3Eu8MuChannel%20%3D%20Hse_Ip_GetFreeChannel(APP_MU_INSTANCE_U8)%3B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88HSE_IP_INVALID_MU_CHANNEL_U8%20%3D%3D%20u8MuChannel%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%7B%3C%2FDIV%3E%3CDIV%3E%E8%BD%AC%E5%88%B0%E5%87%BA%E5%8F%A3%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%E6%B3%A8%E6%84%8F%EF%BC%9A%E9%9C%80%E8%A6%81%E6%8C%87%E5%AE%9A%E5%93%AA%E4%B8%AAMU%E9%80%9A%E9%81%93%EF%BC%9F*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20hseSrvDescriptor_t%20*pHseSrvDesc%20%3D%20%26amp%3BHse_aSrvDescriptor%5Bu8MuChannel%5D%3B%3C%2FDIV%3E%3CDIV%3EhseExportKeySrv_t*%20pExportKeyReq%20%3D%20%26amp%3BpHseSrvDesc-%26gt%3BhseSrv.exportKeyReq%3B%3C%2FDIV%3E%3CDIV%3Ememset(pHseSrvDesc%EF%BC%8C%200%EF%BC%8C%20sizeof(hseSrvDescriptor_t))%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20pHseSrvDesc-%26gt%3BsrvId%20%3D%20HSE_SRV_ID_EXPORT_KEY%3B%3C%2FDIV%3E%3CDIV%3EpExportKeyReq-%26gt%3B%E7%9B%AE%E6%A0%87%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%20%3D%20%E7%9B%AE%E6%A0%87%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EpExportKeyReq-%26gt%3BpKey%5B0%5D%20%3D%20(HOST_ADDR)pPubKey%3B%3C%2FDIV%3E%3CDIV%3EpExportKeyReq-%26gt%3BpKeyLen%5B0%5D%20%3D%20(HOST_ADDR)pPubKeyLength%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EpExportKeyReq-%26gt%3Bcipher.cipherKeyHandle%20%3D%20HSE_INVALID_KEY_HANDLE%3B%3C%2FDIV%3E%3CDIV%3EpExportKeyReq-%26gt%3BkeyContainer.authKeyHandle%20%3D%20HSE_INVALID_KEY_HANDLE%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E6%9E%84%E5%BB%BA%E8%A6%81%E5%8F%91%E9%80%81%E5%88%B0%20HSE%20Ip%20%E5%B1%82%E7%9A%84%E8%AF%B7%E6%B1%82%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3EHseIp_aRequest%5Bu8MuChannel%5D.eReqType%20%3D%20HSE_IP_REQTYPE_SYNC%3B%3C%2FDIV%3E%3CDIV%3EHseIp_aRequest%5Bu8MuChannel%5D.u32Timeout%20%3D%20TIMEOUT_TICKS_U32%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%E6%B3%A8%E6%84%8F%EF%BC%9A%E9%9C%80%E8%A6%81%E6%8C%87%E5%AE%9A%E5%93%AA%E4%B8%AAMU%E9%80%9A%E9%81%93%EF%BC%9F*%2F%3C%2FDIV%3E%3CDIV%3EsrvResponse%20%3D%20Hse_Ip_ServiceRequest(APP_MU_INSTANCE_U8%EF%BC%8C%20u8MuChannel%EF%BC%8C%20%26amp%3BHseIp_aRequest%5Bu8MuChannel%5D%EF%BC%8C%20pHseSrvDesc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%87%BA%E5%8F%A3%EF%BC%9A%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E8%BF%94%E5%9B%9E%20srvResponse%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EhseSrvResponse_t%20HSE_MY_KeyDeriveCopyKey%3C%2FDIV%3E%3CDIV%3E(%3C%2FDIV%3E%3CDIV%3EhseKeyHandle_t%20%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%EF%BC%8C%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20uint16_t%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20%26nbsp%3B%20startOffset%2C%3C%2FDIV%3E%3CDIV%3EhseKeyHandle_t%20%E7%9B%AE%E6%A0%87%E9%94%AE%E5%8F%A5%E6%9F%84%EF%BC%8C%3C%2FDIV%3E%3CDIV%3EhseKeyInfo_t%20%E5%AF%86%E9%92%A5%E4%BF%A1%E6%81%AF%3C%2FDIV%3E%3CDIV%3E)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3Euint8_t%20u8MuChannel%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%E9%94%99%E8%AF%AF%E5%8E%9F%E5%9B%A0%EF%BC%9A%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E5%9C%A8%20u8MuInstance%20%E4%B8%8A%E8%8E%B7%E5%8F%96%E5%85%8D%E8%B4%B9%E9%A2%91%E9%81%93%20*%2F%3C%2FDIV%3E%3CDIV%3Eu8MuChannel%20%3D%20Hse_Ip_GetFreeChannel(APP_MU_INSTANCE_U8)%3B%3C%2FDIV%3E%3CDIV%3E%E5%A6%82%E6%9E%9C%EF%BC%88HSE_IP_INVALID_MU_CHANNEL_U8%20%3D%3D%20u8MuChannel%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%7B%3C%2FDIV%3E%3CDIV%3E%E8%BD%AC%E5%88%B0%E5%87%BA%E5%8F%A3%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%E6%B3%A8%E6%84%8F%EF%BC%9A%E9%9C%80%E8%A6%81%E6%8C%87%E5%AE%9A%E5%93%AA%E4%B8%AAMU%E9%80%9A%E9%81%93%EF%BC%9F*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20hseSrvDescriptor_t%20*pHseSrvDesc%20%3D%20%26amp%3BHse_aSrvDescriptor%5Bu8MuChannel%5D%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20hseKeyDeriveCopyKeySrv_t%20*pExtractKeySrv%20%3D%20%26amp%3B(pHseSrvDesc-%26gt%3BhseSrv.keyDeriveCopyKeyReq)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Ememset(pHseSrvDesc%EF%BC%8C%200%EF%BC%8C%20sizeof(hseSrvDescriptor_t))%3B%3C%2FDIV%3E%3CDIV%3EpHseSrvDesc-%26gt%3BsrvId%20%3D%20HSE_SRV_ID_KEY_DERIVE_COPY%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3B%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%20%3D%20%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%EF%BC%9B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3BstartOffset%20%3D%20startOffset%3B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3BtargetKeyHandle%20%3D%20%E7%9B%AE%E6%A0%87%E5%AF%86%E9%92%A5%E5%8F%A5%E6%9F%84%EF%BC%9B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3B%E5%AF%86%E9%92%A5%E4%BF%A1%E6%81%AF%20%3D%20%E5%AF%86%E9%92%A5%E4%BF%A1%E6%81%AF%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E6%9E%84%E5%BB%BA%E8%A6%81%E5%8F%91%E9%80%81%E5%88%B0%20HSE%20Ip%20%E5%B1%82%E7%9A%84%E8%AF%B7%E6%B1%82%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3EHseIp_aRequest%5Bu8MuChannel%5D.eReqType%20%3D%20HSE_IP_REQTYPE_SYNC%3B%3C%2FDIV%3E%3CDIV%3EHseIp_aRequest%5Bu8MuChannel%5D.u32Timeout%20%3D%20TIMEOUT_TICKS_U32%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%E6%B3%A8%E6%84%8F%EF%BC%9A%E9%9C%80%E8%A6%81%E6%8C%87%E5%AE%9A%E5%93%AA%E4%B8%AAMU%E9%80%9A%E9%81%93%EF%BC%9F*%2F%3C%2FDIV%3E%3CDIV%3EsrvResponse%20%3D%20Hse_Ip_ServiceRequest(APP_MU_INSTANCE_U8%EF%BC%8C%20u8MuChannel%EF%BC%8C%20%26amp%3BHseIp_aRequest%5Bu8MuChannel%5D%EF%BC%8C%20pHseSrvDesc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%87%BA%E5%8F%A3%EF%BC%9A%3C%2FDIV%3E%3CDIV%3E%E8%BF%94%E5%9B%9E%20srvResponse%EF%BC%9B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Eint32_t%20gq_getComputeSharedKey%EF%BC%88uint32_t%20keyHandle%EF%BC%8Cuint8_t%20*keyBuf%EF%BC%89%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%2F*%20uint8_t%20keyBuf%5B32%5D%3B%20*%2F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20uint16_t%20keyBufLen%20%3D%2032%3B%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EhseKeyInfo_t%20%E5%AF%86%E9%92%A5%E4%BF%A1%E6%81%AF%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EhseSrvResponse_t%20srvResponse%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eint32_t%20ret%20%3D%200%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Euint32_t%20%E5%A4%8D%E5%88%B6%E9%94%AE%E6%A7%BD%20%3D%20HSE_INVALID_KEY_HANDLE%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20uint8_t%20export_key%5B32%5D%3D%7B%200%2C%20%7D%3B%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ekey_import_param_t%20key_import_param_shared%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ememset%EF%BC%88%26amp%3Bkey_import_param_shared%EF%BC%8C0x00%EF%BC%8Csizeof%EF%BC%88key_import_param_t%EF%BC%89%EF%BC%89%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E5%A4%8D%E5%88%B6%E5%85%B1%E4%BA%AB%E5%AF%86%E9%92%A5%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ekey_import_param_shared.%E5%AF%86%E9%92%A5%E7%B1%BB%E5%9E%8B%20%3D%20HSE_KEY_TYPE_SHARED_SECRET%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ekey_import_param_shared.key_catalog%20%3D%20HSE_KEY_CATALOG_ID_RAM%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ekey_import_param_shared.key_param.sym_key_param.size%20%3D%20256u%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EKeystoreMgmt_FindAllocateSlot%EF%BC%88%26amp%3Bkey_import_param_shared%EF%BC%8C%26amp%3Bcopykeyslot%EF%BC%89%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ememset(keyBuf%2C%200%2C%20keyBufLen)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EsrvResponse%20%3D%20HSE_GetKeyInfo(keyHandle%2C%20%26amp%3BKeyInfo)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%EF%BC%88srvResponse%20%3D%3D%20HSE_SRV_RSP_OK%EF%BC%89%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%AF%86%E9%92%A5%E4%BF%A1%E6%81%AF.%E5%AF%86%E9%92%A5%E6%A0%87%E5%BF%97%20%3D%20(HSE_KF_USAGE_ENCRYPT%20%7C%20HSE_KF_USAGE_DECRYPT%20%7C%20HSE_KF_USAGE_SIGN%20%7C%20HSE_KF_USAGE_VERIFY%20%7C%20HSE_KF_USAGE_DERIVE)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EKeyInfo.keyType%20%3D%20HSE_KEY_TYPE_SHARED_SECRET%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eprintf(%22copykeyslot%3D0x%2508x%5Cn%22%2C%20copykeyslot)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E5%A4%8D%E5%88%B6%E5%AF%86%E9%92%A5%E6%A7%BD%20%3D%200x00020601%3B%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EsrvResponse%20%3D%20HSE_MY_KeyDeriveCopyKey(keyHandle%EF%BC%8C%200%EF%BC%8C%20copykeyslot%EF%BC%8C%20KeyInfo)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%EF%BC%88srvResponse%EF%BC%81%3DHSE_SRV_RSP_OK%EF%BC%89%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eret%20%3D%20srv%E5%93%8D%E5%BA%94%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eelse%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eprintf(%22HSE_KeyDeriveCopyKey()%20%E6%AD%A3%E5%B8%B8%5Cr%5Cn%22)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EsrvResponse%20%3D%20HSE_KeyDeriveCopyKeyContent%EF%BC%88copykeyslot%EF%BC%8CKeyInfo%EF%BC%8C%EF%BC%86keyBufLen%EF%BC%8CkeyBuf%EF%BC%89%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%EF%BC%88srvResponse%EF%BC%81%3DHSE_SRV_RSP_OK%EF%BC%89%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eret%20%3D%20srv%E5%93%8D%E5%BA%94%EF%BC%9B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eelse%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eprintf(%22HSE_KeyDeriveCopyKeyContent()%20%E6%AD%A3%E5%B8%B8%5Cr%5Cn%22)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eelse%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eret%20%3D%20-2%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7D%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ereturn%20ret%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3C%2FLINGO-BODY%3E