S32K314 question about TLS API with HSE

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

S32K314 question about TLS API with HSE

ソリューションへジャンプ
7,977件の閲覧回数
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,779件の閲覧回数
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,780件の閲覧回数
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,923件の閲覧回数
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,946件の閲覧回数
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%3EHSE%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%9FTLS%20API%E3%81%AB%E9%96%A2%E3%81%99%E3%82%8BS32K314%E8%B3%AA%E5%95%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1993308%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3ES32K314%E5%B9%B4%E3%81%AB%E3%81%AF%E3%80%81%3CBR%20%2F%3ENXP%E3%81%8C%E6%8F%90%E4%BE%9B%E3%81%99%E3%82%8BMbedtls%20RTM%201.0.0%20w%2F%20HSE%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3ETLS%20Handshake%E3%81%AE%E5%BE%8C%E3%80%81%E5%85%B1%E6%9C%89%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88%E3%82%92%E8%A8%88%E7%AE%97%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8B%E3%81%9F%E3%82%81%E3%80%81mbedtls_ecdh_compute_shared()%20API%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E3%81%97%E3%81%8B%E3%81%97%E3%80%81%E3%81%9D%E3%81%AEAPI(mbedtls_ecdh_compute_shared)%E3%81%AF%E3%80%81%E4%B8%8B%E3%81%AE%E5%9B%B3%E3%81%AE%E3%82%88%E3%81%86%E3%81%AB%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%AB%E3%82%92z%E5%80%A4%E3%83%91%E3%83%A9%E3%83%A1%E3%83%BC%E3%82%BF%E3%81%A8%E3%81%97%E3%81%A6%E5%89%B2%E3%82%8A%E5%BD%93%E3%81%A6%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E4%BD%9C%E6%A5%AD%E6%93%8D%E4%BD%9C%E3%81%A7%E3%81%AF%E3%80%81%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%AB%E5%80%A4%E3%81%A7%E3%81%AF%E3%81%AA%E3%81%8F%E3%80%81%E5%AE%9F%E9%9A%9B%E3%81%AE%E5%85%B1%E6%9C%89%E7%A7%98%E5%AF%86%E9%8D%B5%E5%80%A4%E3%82%92%E5%B0%8E%E5%87%BA%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%E3%81%A9%E3%81%86%E3%81%99%E3%82%8C%E3%81%B0%E3%81%84%E3%81%84%E3%81%AE%E3%81%A7%E3%81%97%E3%82%87%E3%81%86%E3%81%8B%3F%E3%82%AC%E3%82%A4%E3%83%89%E3%81%97%E3%81%A6%E3%81%8F%E3%81%A0%E3%81%95%E3%81%84%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3CP%3ETLS%E3%82%B3%E3%83%BC%E3%83%89)%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%E3%82%A2%E3%83%97%E3%83%AA%E3%82%B1%E3%83%BC%E3%82%B7%E3%83%A7%E3%83%B3%E3%82%B3%E3%83%BC%E3%83%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(%26amp%3Becdh.grp%2C%26amp%3Bz%E3%80%81%26amp%3Becdh%E3%80%82Qp%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%20(%22!!%20mbedtls_ecdh_compute_shared%20returned%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(%26amp%3Bz%2C%20sharedSecret%2C%2032)%3B%3C%2FDIV%3E%3CDIV%3Eif%20(tmp_rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT%20(%22!!%20mbedtls_mpi_write_binary%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%E3%83%86%E3%82%B9%E3%83%88%E3%83%AD%E3%82%B0)%3C%2FP%3E%3CP%3E%E7%A7%98%E5%AF%86%E9%8D%B5%E3%83%8F%E3%83%B3%E3%83%89%E3%83%AB%200x20400%20%7C%E3%83%94%E3%82%A2%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%AB%20%3A%200x20500%20%7C%E5%85%B1%E6%9C%89%E7%A7%98%E5%AF%86%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%AB%200x20600%3CBR%20%2F%3EZ%E3%81%AF20600%E3%81%A7%E3%81%99%3CBR%20%2F%3EsharedSecret%3D%3CBR%20%2F%3E00%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%3ERe%3AHSE%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%9FTLS%20API%E3%81%AB%E9%96%A2%E3%81%99%E3%82%8BS32K314%E8%B3%AA%E5%95%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2007786%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E8%A6%AA%E6%84%9B%E3%81%AA%E3%82%8BNXP%E3%81%AE%E7%9A%86%E3%81%95%E3%82%93%E3%80%82%3C%2FP%3E%3CP%3EKDF%20%E3%81%A7%E3%81%AF%E3%80%81NIST%20800-56A%20%E3%81%8C%E7%8F%BE%E5%9C%A8%20NXP%20HSE%20%E3%81%A7%E3%82%B5%E3%83%9D%E3%83%BC%E3%83%88%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%81%AA%E3%81%84%E3%81%93%E3%81%A8%E3%82%92%E7%9F%A5%E3%81%A3%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E3%81%9D%E3%81%93%E3%81%A7%E3%80%81HSE%E3%81%AA%E3%81%97%E3%81%A7%E5%AE%9F%E8%A3%85%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%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%3ERe%3AHSE%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%9FTLS%20API%E3%81%AB%E9%96%A2%E3%81%99%E3%82%8BS32K314%E8%B3%AA%E5%95%8F%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%BB%A5%E4%B8%8B%E3%81%AF%E3%80%81HSE%20%E3%81%8C%E5%AE%9F%E8%A1%8C%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%82%8B%E3%83%97%E3%83%A9%E3%83%83%E3%83%88%E3%83%95%E3%82%A9%E3%83%BC%E3%83%A0%E3%80%81%E3%81%A4%E3%81%BE%E3%82%8A%20MBEDTLS_USE_NXP_HSE_CRYPTO%20%E3%81%8C%E6%9C%89%E5%8A%B9%E3%81%AB%E3%81%AA%E3%81%A3%E3%81%A6%E3%81%84%E3%82%8B%E3%83%97%E3%83%A9%E3%83%83%E3%83%88%E3%83%95%E3%82%A9%E3%83%BC%E3%83%A0%E3%81%A7%E3%80%81tls%20handshaked%20%E5%87%A6%E7%90%86%E3%81%8C%E5%AE%8C%E4%BA%86%E3%81%97%E3%81%9F%E5%BE%8C%E3%81%AB%E8%A8%98%E8%BF%B0%E3%81%95%E3%82%8C%E3%81%9F%E3%82%B3%E3%83%BC%E3%83%89%E3%81%A7%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E3%81%93%E3%82%8C%E3%81%AB%E3%81%AF%E3%80%81%E8%A8%BC%E6%98%8E%E6%9B%B8%E3%81%A8%20DH%20%E5%85%AC%E9%96%8B%E9%8D%B5%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E6%B4%BE%E7%94%9F%E3%82%AD%E3%83%BC%E3%82%92%E7%94%9F%E6%88%90%E3%81%99%E3%82%8B%E3%83%97%E3%83%AD%E3%82%BB%E3%82%B9%E3%80%81AES%20%E3%81%AB%E3%82%88%E3%82%8B%E7%A7%98%E5%AF%86%E9%8D%B5%E3%81%AE%E5%BE%A9%E5%8F%B7%E5%8C%96%E3%80%81ECC%20%E3%82%B3%E3%83%B3%E3%83%86%E3%82%AD%E3%82%B9%E3%83%88%E3%81%B8%E3%81%AE%E5%89%B2%E3%82%8A%E5%BD%93%E3%81%A6%E3%80%81%E3%81%8A%E3%82%88%E3%81%B3%E7%BD%B2%E5%90%8D%E7%94%9F%E6%88%90%E3%83%97%E3%83%AD%E3%82%BB%E3%82%B9%E3%81%8C%E5%90%AB%E3%81%BE%E3%82%8C%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E3%81%A4%E3%81%BE%E3%82%8A%E3%80%81%E8%A8%BC%E6%98%8E%E6%9B%B8%E3%81%A8%20DH%20%E5%85%AC%E9%96%8B%E3%82%AD%E3%83%BC%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E6%9A%97%E5%8F%B7%E5%8C%96%E3%82%AD%E3%83%BC%E3%81%8C%E4%BD%9C%E6%88%90%E3%81%95%E3%82%8C%E3%80%81mbedtls_ssl_tls_prf()%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%82%AD%E3%83%BC%E3%81%8C%E5%B0%8E%E5%87%BA%E3%81%95%E3%82%8C%E3%80%81%E6%AC%A1%E3%81%AB%E7%A7%98%E5%AF%86%E3%82%AD%E3%83%BC%20(%E5%87%BA%E5%8A%9B)%20%E3%81%8C%20AES%20%E3%82%92%E4%BB%8B%E3%81%97%E3%81%A6%E4%BD%9C%E6%88%90%E3%81%95%E3%82%8C%E3%80%81ECC%20%E3%82%B3%E3%83%B3%E3%83%86%E3%82%AD%E3%82%B9%E3%83%88%E3%81%AB%E5%89%B2%E3%82%8A%E5%BD%93%E3%81%A6%E3%82%89%E3%82%8C%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E3%81%97%E3%81%8B%E3%81%97%E3%80%81%E8%AA%8D%E5%8F%AF%E8%A6%81%E6%B1%82%E3%83%97%E3%83%AD%E3%82%BB%E3%82%B9%E3%81%A7%E3%81%AF%E3%80%81%E4%BD%9C%E6%88%90%E3%81%95%E3%82%8C%E3%81%9FSignatureValue%E3%81%AF%E3%80%81%E8%AA%8D%E8%A8%BC%E5%BF%9C%E7%AD%94%E3%81%A7%E9%96%93%E9%81%95%E3%81%A3%E3%81%9F%E7%BD%B2%E5%90%8D%E3%81%A7%E5%BF%9C%E7%AD%94%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSTRONG%3E1.%E3%82%AD%E3%83%BC%E3%81%AE%E5%B0%8E%E5%87%BA%E3%81%AB%E3%81%AF%E3%80%81mbedtls_ssl_tls_prf()%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%80%81%E3%83%A9%E3%83%99%E3%83%AB%E3%81%AF%E6%AD%A3%E3%81%97%E3%81%84%E3%81%A7%E3%81%99%E3%81%8B%3F%E3%81%9D%E3%81%86%E3%81%A7%E3%81%AA%E3%81%84%E3%81%8B%E3%81%A9%E3%81%86%E3%81%8B%3F%3C%2FSTRONG%3E%3C%2FDIV%3E%3CDIV%3E%E3%80%8C%E3%82%A8%E3%82%AF%E3%82%B9%E3%82%BF%E3%83%BC%E3%83%B3%E3%83%89%E3%83%9E%E3%82%B9%E3%82%BF%E3%83%BC%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88%E3%80%8D%E3%81%A8%E3%80%8C%E3%82%AD%E3%83%BC%E6%8B%A1%E5%BC%B5%E3%80%8D%E3%81%AE%E3%81%A9%E3%81%A1%E3%82%89%E3%81%A7%E3%81%99%E3%81%8B%3F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSTRONG%3E2.%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E3%81%AB%E4%BD%95%E3%81%8B%E5%95%8F%E9%A1%8C%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F%3C%2FSTRONG%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E8%AA%8D%E8%A8%BCInstatllResponse%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%2F*%E7%9C%81%E7%95%A5*%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(%26amp%3Boem_key)%3B%3C%2FDIV%3E%3CDIV%3Embedtls_mpi_init(%26amp%3Bd)%3B%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%E3%80%81gq_cert_passphrase_len)%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%20(%22!!%E5%A4%B1%E6%95%97%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(%26amp%3Bd%2C%20%26amp%3Boem_ecp-%26gt%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%3ESYS_CONSOLE_PRINT%20(%22!!%20mbedtls_mpi_copy%20returned%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Embedtls_pk_free(%26amp%3Boem_key)%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%2F*%20DHpublickey%20*%2F%3C%2FDIV%3E%3CDIV%3E%2F*%20ContractSignatureEncryptedPrivateKey%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*%20ecdh%20%E6%A7%8B%E9%80%A0%E4%BD%93%E3%81%AE%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%E3%82%92SECP256R1%E6%9B%B2%E7%B7%9A%E3%81%A7%E5%88%9D%E6%9C%9F%E5%8C%96%E3%81%97%E3%81%BE%E3%81%99%E3%80%82*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_group_load(%26amp%3Becdh.grp%2CMBEDTLS_ECP_DP_SECP256R1)%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%20(%22!!%20mbedtls_ecp_group_load%20%25d%5Cr%5Cn%22%2C%20rc)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20%E4%BB%96%E3%81%AE%E3%82%B7%E3%82%B9%E3%83%86%E3%83%A0%E3%81%8B%E3%82%89%E5%85%AC%E9%96%8B%E9%8D%B5%E3%82%92%E3%83%90%E3%82%A4%E3%83%8A%E3%83%AA%E3%83%87%E3%83%BC%E3%82%BF%E5%BD%A2%E5%BC%8F%E3%81%A7%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%82%93%E3%81%A7%20ecdh%20%E3%81%AB%E9%81%A9%E7%94%A8%E3%81%97%E3%81%BE%E3%81%99%E3%80%82Qp%E3%81%AE%20*%2F%3C%2FDIV%3E%3CDIV%3Ebytes%20%3D%20res-%26gt%3BDHpublickey-%26gt%3BCONTENT-%26gt%3B%E3%83%90%E3%82%A4%E3%83%88%3B%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...%20len%20%25d)%5Cr%5Cn%22%2C%20__func__%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%E3%82%82%E3%81%97%20(temp_shared)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3Ememcpy(temp_shared%2C%20bytes%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_point_read_binary(%26amp%3Becdh.grp%2C%26amp%3Becdh%E3%81%A7%E3%81%99%E3%80%82Qp%2C%20temp_shared%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20nxp_hse_ecp_point_read_binary(%26amp%3Becdh.grp%2C%26amp%3Becdh%E3%81%A7%E3%81%99%E3%80%82Qp%2C%20temp_shared%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%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%E3%81%8C%E5%A4%B1%E6%95%97%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%20-%26gt%3B%20%E3%81%A8%E3%81%AB%E3%81%8B%E3%81%8F%E8%A1%8C%E3%81%8D%E3%81%BE%E3%81%99%5Cr%5Cn%22)%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_point_read_binary(%26amp%3Becdh.grp%2C%26amp%3Becdh%E3%81%A7%E3%81%99%E3%80%82Qp%2C%20bytes%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%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%20bytes%2C%20bytesLen)%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20d%20%E5%80%A4%E3%81%8C%20SECP256R1%20%E3%81%AE%E6%9C%89%E5%8A%B9%E3%81%AA%E7%A7%98%E5%AF%86%E9%8D%B5%E3%81%A7%E3%81%82%E3%82%8B%E3%81%93%E3%81%A8%E3%82%92%E7%A2%BA%E8%AA%8D%E3%81%97%E3%81%A6%E3%81%8F%E3%81%A0%E3%81%95%E3%81%84%20*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_check_privkey(%26amp%3Becdh.grp%2C%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%20(%22%E7%84%A1%E5%8A%B9%E3%81%AA%E7%A7%98%E5%AF%86%E9%8D%B5%3A%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%2F*%20%E5%85%AC%E9%96%8B%E9%8D%B5%E3%81%8C%E6%9C%89%E5%8A%B9%E3%81%AA%E7%AF%84%E5%9B%B2%E5%86%85%E3%81%AB%E3%81%82%E3%82%8B%E3%81%93%E3%81%A8%E3%82%92%E7%A2%BA%E8%AA%8DSECP256R1%20*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecp_check_pubkey(%26amp%3Becdh.grp%2C%26amp%3Becdh%E3%81%A7%E3%81%99%E3%80%82Qp)%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%20(%22DHpublickey%20%E3%81%AF%E7%84%A1%E5%8A%B9%E3%81%A7%E3%81%99%3A%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%3C%2FDIV%3E%3CDIV%3E%2F*%20%E5%85%B1%E6%9C%89%E7%A7%98%E5%AF%86%E9%8D%B5%E3%82%92%E8%A8%88%E7%AE%97%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%E3%81%93%E3%81%93%E3%81%A7%E3%80%81d%20%E3%81%AF%E5%89%8D%E3%81%AE%E6%89%8B%E9%A0%86%E3%81%A7%E7%94%9F%E6%88%90%E3%81%95%E3%82%8C%E3%81%9F%E7%A7%98%E5%AF%86%E9%8D%B5%E3%81%A7%E3%81%99%E3%80%82*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ecdh_compute_shared(%26amp%3Becdh.grp%2C%26amp%3Bz%E3%80%81%26amp%3Becdh%E3%80%82Qp%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%20(%22!!%20mbedtls_ecdh_compute_shared%20returned%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%E5%85%B1%E6%9C%89%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88%E3%80%81%E3%83%A9%E3%83%99%E3%83%AB%E3%80%81%E3%81%9D%E3%81%AE%E4%BB%96%E3%81%AE%E6%83%85%E5%A0%B1%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%82%AD%E3%83%BC%E3%82%92%E5%B0%8E%E5%87%BA%E3%81%97%E3%81%BE%E3%81%99%20*%2F%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_ssl_tls_prf(%3C%2FDIV%3E%3CDIV%3EMBEDTLS_SSL_TLS_PRF_SHA256%2C%20%2F*%20%E3%83%8F%E3%83%83%E3%82%B7%E3%83%A5%E9%96%A2%E6%95%B0%20(%E9%80%9A%E5%B8%B8%E3%81%AF%20TLS%20%E3%81%AE%E5%A0%B4%E5%90%88%E3%81%AF%20SHA-256)%20*%2F%3C%2FDIV%3E%3CDIV%3E%26amp%3Bz%2C%20%2F%2F%26amp%3Bkeyhandle%2C%20%2F*%20%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88%E3%83%87%E3%83%BC%E3%82%BF%20(%E5%85%B1%E6%9C%89%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88)%20*%2F%3C%2FDIV%3E%3CDIV%3E32%2C%20%2F*%20%E5%85%B1%E6%9C%89%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88%E3%81%AE%E9%95%B7%E3%81%95%20*%2F%3C%2FDIV%3E%3CDIV%3E%22externed%20master%20secret%22%2C%20%2F%2F%22extended%20master%20secret%22%2C%20%2F%2F%22master%20secret%22%2C%20%2F%2F%22key%20expansion%22%3C%2FDIV%3E%3CDIV%3EotherInfo%2C%20%2F*%20%E8%BF%BD%E5%8A%A0%E3%83%87%E3%83%BC%E3%82%BF%20(%E3%82%AA%E3%83%97%E3%82%B7%E3%83%A7%E3%83%B3)%20*%2F%3C%2FDIV%3E%3CDIV%3E(int)sizeof(otherInfo)%2C%20%2F*%20%E8%BF%BD%E5%8A%A0%E3%83%87%E3%83%BC%E3%82%BF%E3%81%AE%E9%95%B7%E3%81%95%20*%2F%3C%2FDIV%3E%3CDIV%3Ekey%2C%20%2F*%20%E6%B4%BE%E7%94%9F%E3%82%AD%E3%83%BC%E3%81%AE%E5%87%BA%E5%8A%9B%E3%83%90%E3%83%83%E3%83%95%E3%82%A1%20*%2F%3C%2FDIV%3E%3CDIV%3E(int)sizeof(key)%20%2F*%20%E6%B4%BE%E7%94%9F%E3%82%AD%E3%83%BC%E3%80%81%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%AB%E3%81%AE%E5%B8%8C%E6%9C%9B%E3%81%AE%E9%95%B7%E3%81%95%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%20(%22!!%20mbedtls_ssl_tls_prf()%20%E3%81%8C%E3%82%A8%E3%83%A9%E3%83%BC%20-0x%2504X%5Cn%20%E3%81%A7%E5%A4%B1%E6%95%97%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%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%3Eif%20(tmp_rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT(%22!!%20mbedtls_aes_setkey_dec%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%3Ebytes%20%3D%20res-%26gt%3BContractSignatureEncryptedPrivateKey-%26gt%3BCONTENT-%26gt%3B%E3%83%90%E3%82%A4%E3%83%88%3B%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(iv%2C%20%E3%83%90%E3%82%A4%E3%83%88%2C%2016)%3B%3C%2FDIV%3E%3CDIV%3E%E5%85%A5%E5%8A%9B%20%3D%20%E3%83%90%E3%82%A4%E3%83%88%20%2B%2016%3B%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%E3%82%82%E3%81%97%20(temp_input)%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%3Eif%20(tmp_rc%20!%3D%200)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3ESYS_CONSOLE_PRINT%20(%22!!%20mbedtls_aes_crypt_cbc%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%E3%81%AB%E5%A4%B1%E6%95%97%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%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(%26amp%3Biso-%26gt%3Bcontract_key)%3B%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_pk_setup(%26amp%3Biso-%26gt%3Bcontract_key%2C%20pk_info)%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(%22!!%E5%A4%B1%E6%95%97mbedtls_pk_setup%5Cr%5Cn%22)%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(%22!!%E5%A4%B1%E6%95%97mbedtls_ecp_group_load%5Cr%5Cn%22)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EisoPrintDumpBytes(%22%E7%A7%98%E5%AF%86%E9%8D%B5%22%2C%20%E5%87%BA%E5%8A%9B%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%E3%81%84%E3%81%84%E3%81%88%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*%20uds%20%E3%83%90%E3%83%83%E3%83%95%E3%82%A1%E3%82%92%E8%A7%A3%E6%94%BE%E3%81%99%E3%82%8B%20*%2F%3C%2FDIV%3E%3CDIV%3Eput_gq_uds_buffer()%3B%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%E5%87%BA%E5%8A%9B%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(%22!!%E5%A4%B1%E6%95%97mbedtls_mp_read_binary%5Cn%22)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Eif%20(temp_shared%20!%3D%20NULL)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3EvPortFree(temp_shared)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3Embedtls_mpi_free(%26amp%3Bz)%3B%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(%26amp%3Becdh)%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%E7%9C%81%E7%95%A5*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EcreateSignature%20%E3%81%AE%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%E7%9C%81%E7%95%A5*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3Erc%20%3D%20mbedtls_pk_sign(%26amp%3Biso-%26gt%3Bcontract_key%2C%20MBEDTLS_MD_SHA256%2C%20hash2%2C%2032%2C%20asn%2C%20%26amp%3Bsiglen%2C%20mbedtls_ctr_drbg_random%2C%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%20(%22mbedtls_pk_sign%E5%A4%B1%E6%95%97%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%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(%E6%A7%8B%E9%80%A0%E4%BD%93%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%3ESignatureValue-%26gt%3BCONTENT-%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%3Eif%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%3Eif%20(asn%5Bs_index%5D%20%3D%3D%2033)%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*%E7%9C%81%E7%95%A5*%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%3ERe%3AHSE%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%9FTLS%20API%E3%81%AB%E9%96%A2%E3%81%99%E3%82%8BS32K314%E8%B3%AA%E5%95%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1994187%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E6%A7%98%3C%2FP%3E%3CDIV%3E%E5%95%8F%E9%A1%8C%E7%82%B9%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AF%E3%80%81%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E3%81%AF%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%A9%E3%82%92%E4%BB%8B%E3%81%97%E3%81%A6%E8%BF%BD%E5%8A%A0%E3%81%AE%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%A9%E3%82%92%E3%82%B3%E3%83%94%E3%83%BC%E3%81%97%E3%80%81%E3%81%9D%E3%82%8C%E3%82%92%E3%82%A8%E3%82%AF%E3%82%B9%E3%83%9D%E3%83%BC%E3%83%88%E3%81%97%E3%81%A6%E3%82%AD%E3%83%BC%E5%80%A4%E3%82%92%E5%8F%96%E5%BE%97%E3%81%97%E3%80%81%E6%AC%A1%E3%81%AE%E3%82%88%E3%81%86%E3%81%AB%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E3%82%92%E5%AE%9F%E8%A3%85%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%20sw.2%E3%81%A4%E8%B3%AA%E5%95%8F%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E1.%E4%BB%A5%E4%B8%8B%E3%82%92%E5%AE%9F%E8%A1%8C%E3%81%99%E3%82%8B%E3%81%A8%E3%80%81HSE_MY_KeyDeriveCopyKey()%E3%81%AFHSE_SRV_RSP_INVALID_PARAM%E3%82%92%E8%BF%94%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%E4%BD%95%E3%81%8C%E5%95%8F%E9%A1%8C%E3%81%AA%E3%81%AE%E3%81%8B%E6%95%99%E3%81%88%E3%81%A6%E3%81%84%E3%81%9F%E3%81%A0%E3%81%91%E3%81%BE%E3%81%99%E3%81%8B%3F%3C%2FDIV%3E%3CDIV%3E2.%20%E5%85%B1%E6%9C%89%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88(DH%E3%82%AD%E3%83%BC%E4%BA%A4%E6%8F%9B%E3%83%97%E3%83%AD%E3%83%88%E3%82%B3%E3%83%AB%E3%81%A7%E4%BD%BF%E7%94%A8)%E3%81%AE%E5%80%A4%E3%82%92%E9%80%9A%E5%B8%B8%E3%81%A9%E3%81%8A%E3%82%8A%E5%8F%96%E5%BE%97%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%99%E3%81%8B%3F%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E9%9D%99%E7%9A%84hseSrvResponse_t%20HSE_KeyDeriveCopyKeyContent%3C%2FDIV%3E%3CDIV%3E(%3C%2FDIV%3E%3CDIV%3EhseKeyHandle_t%20targetKeyHandle%E3%80%81%3C%2FDIV%3E%3CDIV%3EhseKeyInfo_t%20keyInfo%E3%80%81%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Euint16_t%20*pPubKeyLength%E3%80%81%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%3B%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*%20u8MuInstance%E3%81%A7%E7%84%A1%E6%96%99%E3%83%81%E3%83%A3%E3%83%B3%E3%83%8D%E3%83%AB%E3%82%92%E5%8F%96%E5%BE%97%20*%2F%3C%2FDIV%3E%3CDIV%3Eu8MuChannel%20%3D%20Hse_Ip_GetFreeChannel(APP_MU_INSTANCE_U8)%3B%3C%2FDIV%3E%3CDIV%3Eif(HSE_IP_INVALID_MU_CHANNEL_U8%20%3D%3D%20u8MuChannel)%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%7B%3C%2FDIV%3E%3CDIV%3Egoto%E5%87%BA%E5%8F%A3%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%E6%B3%A8%3A%E3%81%A9%E3%81%AEMU%E3%83%81%E3%83%A3%E3%83%8D%E3%83%AB%E3%82%92%E6%8C%87%E5%AE%9A%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F*%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%2C%200%2C%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%3BtargetKeyHandle%20%3D%20targetKeyHandle%3B%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*%20Hse%20IP%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%E3%81%AB%E9%80%81%E4%BF%A1%E3%81%99%E3%82%8B%E3%83%AA%E3%82%AF%E3%82%A8%E3%82%B9%E3%83%88%E3%82%92%E4%BD%9C%E6%88%90%E3%81%97%E3%81%BE%E3%81%99%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%3A%E3%81%A9%E3%81%AEMU%E3%83%81%E3%83%A3%E3%83%8D%E3%83%AB%E3%82%92%E6%8C%87%E5%AE%9A%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F*%2F%3C%2FDIV%3E%3CDIV%3EsrvResponse%20%3D%20Hse_Ip_ServiceRequest(APP_MU_INSTANCE_U8%2C%20u8MuChannel%2C%20%26amp%3BHseIp_aRequest%5Bu8MuChannel%5D%2C%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%3EsrvResponse%20%E3%82%92%E8%BF%94%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%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%20keyHandle%E3%80%81%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%20targetKeyHandle%E3%80%81%3C%2FDIV%3E%3CDIV%3EkeyInfo%20hseKeyInfo_t%3C%2FDIV%3E%3CDIV%3E)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3Euint8_t%20u8MuChannel%3B%3C%2FDIV%3E%3CDIV%3EhseSrvResponse_t%20srvResponse%20%3D%20HSE_SRV_RSP_GENERAL_ERROR%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%2F*%20u8MuInstance%E3%81%A7%E7%84%A1%E6%96%99%E3%83%81%E3%83%A3%E3%83%B3%E3%83%8D%E3%83%AB%E3%82%92%E5%8F%96%E5%BE%97%20*%2F%3C%2FDIV%3E%3CDIV%3Eu8MuChannel%20%3D%20Hse_Ip_GetFreeChannel(APP_MU_INSTANCE_U8)%3B%3C%2FDIV%3E%3CDIV%3Eif(HSE_IP_INVALID_MU_CHANNEL_U8%20%3D%3D%20u8MuChannel)%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%20%26nbsp%3B%20%7B%3C%2FDIV%3E%3CDIV%3Egoto%E5%87%BA%E5%8F%A3%3B%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%E6%B3%A8%3A%E3%81%A9%E3%81%AEMU%E3%83%81%E3%83%A3%E3%83%8D%E3%83%AB%E3%82%92%E6%8C%87%E5%AE%9A%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F*%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%2C%200%2C%20sizeof(hseSrvDescriptor_t))%3B%3C%2FDIV%3E%3CDIV%3EpHseSrvDesc-%26gt%3BsrvId%20%3D%20HSE_SRV_ID_KEY_DERIVE_COPY%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3BkeyHandle%20%3D%20%E3%82%AD%E3%83%BC%E3%83%8F%E3%83%B3%E3%83%89%E3%83%AB%3B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3BstartOffset%20%3D%20startOffset%3B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3BtargetKeyHandle%20%3D%20targetKeyHandle%3B%3C%2FDIV%3E%3CDIV%3EpExtractKeySrv-%26gt%3BkeyInfo%20%3D%20%E3%82%AD%E3%83%BC%E3%82%A4%E3%83%B3%E3%83%95%E3%82%A9%3B%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20Hse%20IP%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%E3%81%AB%E9%80%81%E4%BF%A1%E3%81%99%E3%82%8B%E3%83%AA%E3%82%AF%E3%82%A8%E3%82%B9%E3%83%88%E3%82%92%E4%BD%9C%E6%88%90%E3%81%97%E3%81%BE%E3%81%99%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%3A%E3%81%A9%E3%81%AEMU%E3%83%81%E3%83%A3%E3%83%8D%E3%83%AB%E3%82%92%E6%8C%87%E5%AE%9A%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F*%2F%3C%2FDIV%3E%3CDIV%3EsrvResponse%20%3D%20Hse_Ip_ServiceRequest(APP_MU_INSTANCE_U8%2C%20u8MuChannel%2C%20%26amp%3BHseIp_aRequest%5Bu8MuChannel%5D%2C%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%3EsrvResponse%20%E3%82%92%E8%BF%94%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%7D%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3Eint32_t%20gq_getComputeSharedKey(uint32_t%20keyHandle%2C%20uint8_t%20*keyBuf)%3C%2FDIV%3E%3CDIV%3E%7B%3C%2FDIV%3E%3CDIV%3E%2F*%20uint8_t%20keyBuf%5B32%5D%3B*%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%E3%82%AD%E3%83%BC%E6%83%85%E5%A0%B1%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EhseSrvResponse_t%20srvResponse%3B%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%20copykeyslot%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%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ememset(%26amp%3Bkey_import_param_shared%2C%200x00%2C%20sizeof(key_import_param_t))%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%2F*%20%E5%85%B1%E6%9C%89%E3%82%B7%E3%83%BC%E3%82%AF%E3%83%AC%E3%83%83%E3%83%88%E3%82%AD%E3%83%BC%E3%81%AE%E3%82%B3%E3%83%94%E3%83%BC%20*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Ekey_import_param_shared.key_type%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(%26amp%3Bkey_import_param_shared%2C%20%26amp%3Bcopykeyslot)%3B%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%3Eif(srvResponse%20%3D%3D%20HSE_SRV_RSP_OK)%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EKeyInfo.keyFlags%20%3D%20(HSE_KF_USAGE_ENCRYPT%20%7CHSE_KF_USAGE_DECRYPT%20%7CHSE_KF_USAGE_SIGN%20%7CHSE_KF_USAGE_VERIFY%20%7CHSE_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*%20copykeyslot%20%3D%200x00020601%3B*%2F%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EsrvResponse%20%3D%20HSE_MY_KeyDeriveCopyKey(keyHandle%2C%200%2C%20copykeyslot%2C%20KeyInfo)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eif(srvResponse%20!%3D%20HSE_SRV_RSP_OK)%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eret%20%3D%20srvResponse%3B%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%E3%81%AF%E5%A4%A7%E4%B8%88%E5%A4%AB%E3%81%A7%E3%81%99%5Cr%5Cn%22)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3EsrvResponse%20%3D%20HSE_KeyDeriveCopyKeyContent(copykeyslot%2C%20KeyInfo%2C%20%26amp%3BkeyBufLen%2C%20keyBuf)%3B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eif(srvResponse%20!%3D%20HSE_SRV_RSP_OK)%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E%7B%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3Eret%20%3D%20srvResponse%3B%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%E3%81%AF%E5%95%8F%E9%A1%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%9B%E3%82%93%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