C++程序  |  49行  |  1.65 KB

/*############################################################################
  # Copyright 2017 Intel Corporation
  #
  # Licensed under the Apache License, Version 2.0 (the "License");
  # you may not use this file except in compliance with the License.
  # You may obtain a copy of the License at
  #
  #     http://www.apache.org/licenses/LICENSE-2.0
  #
  # Unless required by applicable law or agreed to in writing, software
  # distributed under the License is distributed on an "AS IS" BASIS,
  # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  # See the License for the specific language governing permissions and
  # limitations under the License.
  ############################################################################*/
/// Definition of pairing math
/*! \file */

#ifndef EPID_MEMBER_TINY_MATH_PAIRING_H_
#define EPID_MEMBER_TINY_MATH_PAIRING_H_
/*!
 * \file
 * \brief Tiny portable implementations of standard library functions
 */
/// \cond
typedef struct Fq12Elem Fq12Elem;
typedef struct EccPointFq EccPointFq;
typedef struct EccPointFq2 EccPointFq2;
typedef struct PairingState PairingState;
/// \endcond

/// Initializes pairing environment.
/*!
\param[out] state pairing state information.
*/
void PairingInit(PairingState* state);

/// Computes a pairing according to the Optimal Ate pairing computation
/*!
\param[out] d target, an element in GT.
\param[in] P an element in G1.
\param[in] Q an element in G2.
\param[in,out] state pairing state information.
*/
void PairingCompute(Fq12Elem* d, EccPointFq const* P, EccPointFq2 const* Q,
                    PairingState const* state);

#endif  // EPID_MEMBER_TINY_MATH_PAIRING_H_