/* Microsoft Reference Implementation for TPM 2.0 | |
* | |
* The copyright in this software is being made available under the BSD License, | |
* included below. This software may be subject to other third party and | |
* contributor rights, including patent rights, and no such rights are granted | |
* under this license. | |
* | |
* Copyright (c) Microsoft Corporation | |
* | |
* All rights reserved. | |
* | |
* BSD License | |
* | |
* Redistribution and use in source and binary forms, with or without modification, | |
* are permitted provided that the following conditions are met: | |
* | |
* Redistributions of source code must retain the above copyright notice, this list | |
* of conditions and the following disclaimer. | |
* | |
* Redistributions in binary form must reproduce the above copyright notice, this | |
* list of conditions and the following disclaimer in the documentation and/or other | |
* materials provided with the distribution. | |
* | |
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ""AS IS"" | |
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR | |
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | |
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | |
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON | |
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | |
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
*/ | |
/*(Auto) | |
Automatically Generated by TpmPrototypes version 2.2 February 10, 2016 | |
Date: Sep 9, 2016 Time: 01:03:57 PM | |
*/ | |
#ifndef _CRYPTECCKEYEXCHANGE_FP_H_ | |
#define _CRYPTECCKEYEXCHANGE_FP_H_ | |
#if CC_ZGen_2Phase == YES //% | |
//*** CryptEcc2PhaseKeyExchange() | |
// This function is the dispatch routine for the EC key exchange functions that use | |
// two ephemeral and two static keys. | |
// return type: TPM_RC | |
// TPM_RC_SCHEME scheme is not defined | |
LIB_EXPORT TPM_RC | |
CryptEcc2PhaseKeyExchange( | |
TPMS_ECC_POINT *outZ1, // OUT: a computed point | |
TPMS_ECC_POINT *outZ2, // OUT: and optional second point | |
TPM_ECC_CURVE curveId, // IN: the curve for the computations | |
TPM_ALG_ID scheme, // IN: the key exchange scheme | |
TPM2B_ECC_PARAMETER *dsA, // IN: static private TPM key | |
TPM2B_ECC_PARAMETER *deA, // IN: ephemeral private TPM key | |
TPMS_ECC_POINT *QsB, // IN: static public party B key | |
TPMS_ECC_POINT *QeB // IN: ephemeral public party B key | |
); | |
#ifdef TPM_ALG_SM2 | |
// SM2KeyExchange() | |
// This function performs the key exchange defined in SM2. | |
// The first step is to compute | |
// 'tA' = ('dsA' + 'deA' avf(Xe,A)) mod n | |
// Then, compute the Z value from | |
// 'outZ' = ('h' 'tA' mod 'n') ('QsA' + [avf(QeB.x)](QeB)). | |
// The function will compute the ephemeral public key from the ephemeral | |
// private key. | |
// All points are required to be on the curve of inQsA. The function will fail | |
// catastrophically if this is not the case | |
// return type: TPM_RC | |
// TPM_RC_SUCCESS results is valid | |
// TPM_RC_NO_RESULTS the value for dsA does not give a valid point on the | |
// curve | |
LIB_EXPORT TPM_RC | |
SM2KeyExchange( | |
TPMS_ECC_POINT *outZ, // OUT: the computed point | |
TPM_ECC_CURVE curveId, // IN: the curve for the computations | |
TPM2B_ECC_PARAMETER *dsAIn, // IN: static private TPM key | |
TPM2B_ECC_PARAMETER *deAIn, // IN: ephemeral private TPM key | |
TPMS_ECC_POINT *QsBIn, // IN: static public party B key | |
TPMS_ECC_POINT *QeBIn // IN: ephemeral public party B key | |
); | |
#endif | |
#endif //% CC_ZGen_2Phase | |
#endif // _CRYPTECCKEYEXCHANGE_FP_H_ |