C++程序  |  142行  |  5.39 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.
  ############################################################################*/
/// Tiny portable implementations of standard library functions
/*! \file */

#include "epid/member/tiny/src/serialize.h"
#include <stddef.h>

#include "epid/common/types.h"
#include "epid/member/tiny/math/serialize.h"
#include "epid/member/tiny/src/native_types.h"
#include "epid/member/tiny/src/signbasic.h"

void* BasicSignatureSerialize(BasicSignature* dest,
                              NativeBasicSignature const* src) {
#if defined(UNOPTIMIZED_SERIALIZATION)
  EFqSerialize(&dest->B, &src->B);
  EFqSerialize(&dest->K, &src->K);
  EFqSerialize(&dest->T, &src->T);
  FpSerialize(&dest->c, &src->c);
  FpSerialize(&dest->sx, &src->sx);
  FpSerialize(&dest->sf, &src->sf);
  FpSerialize(&dest->sa, &src->sa);
  FpSerialize(&dest->sb, &src->sb);
  return dest + 1;
#else   // defined(UNOPTIMIZED_SERIALIZATION)
  SwapNativeAndPortableLayout(dest, sizeof(*dest), src, sizeof(*src));
  return dest + 1;
#endif  // defined(UNOPTIMIZED_SERIALIZATION)
}

void const* BasicSignatureDeserialize(NativeBasicSignature* dest,
                                      BasicSignature const* src) {
#if defined(UNOPTIMIZED_SERIALIZATION)
  EFqDeserialize(&dest->B, &src->B);
  EFqDeserialize(&dest->K, &src->K);
  EFqDeserialize(&dest->T, &src->T);
  FpDeserialize(&dest->c, &src->c);
  FpDeserialize(&dest->sx, &src->sx);
  FpDeserialize(&dest->sf, &src->sf);
  FpDeserialize(&dest->sa, &src->sa);
  FpDeserialize(&dest->sb, &src->sb);
  return src + 1;
#else   // defined(UNOPTIMIZED_SERIALIZATION)
  SwapNativeAndPortableLayout(dest, sizeof(*dest), src, sizeof(*src));
  return src + 1;
#endif  // defined(UNOPTIMIZED_SERIALIZATION)
}

void* GroupPubKeySerialize(GroupPubKey* dest, NativeGroupPubKey const* src) {
#if defined(UNOPTIMIZED_SERIALIZATION)
  EFqSerialize(&dest->h1, &src->h1);
  EFqSerialize(&dest->h2, &src->h2);
  EFq2Serialize(&dest->w, &src->w);
  dest->gid = src->gid;
  return dest + 1;
#else   // defined(UNOPTIMIZED_SERIALIZATION)
  dest->gid = src->gid;
  SwapNativeAndPortableLayout(
      (uint8_t*)dest + sizeof(dest->gid), sizeof(*dest) - sizeof(dest->gid),
      (uint8_t*)src + sizeof(src->gid), sizeof(*src) - sizeof(src->gid));
  return dest + 1;
#endif  // defined(UNOPTIMIZED_SERIALIZATION)
}

void const* GroupPubKeyDeserialize(NativeGroupPubKey* dest,
                                   GroupPubKey const* src) {
#if defined(UNOPTIMIZED_SERIALIZATION)
  EFqDeserialize(&dest->h1, &src->h1);
  EFqDeserialize(&dest->h2, &src->h2);
  EFq2Deserialize(&dest->w, &src->w);
  dest->gid = src->gid;
  return src + 1;
#else   // defined(UNOPTIMIZED_SERIALIZATION)
  dest->gid = src->gid;
  SwapNativeAndPortableLayout(
      (uint8_t*)dest + sizeof(dest->gid), sizeof(*dest) - sizeof(dest->gid),
      (uint8_t*)src + sizeof(src->gid), sizeof(*src) - sizeof(src->gid));
  return src + 1;
#endif  // defined(UNOPTIMIZED_SERIALIZATION)
}

void const* PrivKeyDeserialize(NativePrivKey* dest, PrivKey const* src) {
#if defined(UNOPTIMIZED_SERIALIZATION)
  EFqDeserialize(&dest->cred.A, &src->A);
  FpDeserialize(&dest->cred.x, &src->x);
  FpDeserialize(&dest->f, &src->f);
  dest->cred.gid = src->gid;
  return src + 1;
#else   // defined(UNOPTIMIZED_SERIALIZATION)
  dest->cred.gid = src->gid;
  SwapNativeAndPortableLayout((uint8_t*)dest + sizeof(dest->cred.gid),
                              sizeof(*dest) - sizeof(dest->cred.gid),
                              (uint8_t*)src + sizeof(src->gid),
                              sizeof(*src) - sizeof(src->gid));
  return src + 1;
#endif  // defined(UNOPTIMIZED_SERIALIZATION)
}

void const* PreCompDeserialize(NativeMemberPrecomp* dest,
                               MemberPrecomp const* src) {
#if defined(UNOPTIMIZED_SERIALIZATION)
  Fq12Deserialize(&dest->ea2, (Fq12ElemStr*)&src->ea2);
  Fq12Deserialize(&dest->e12, (Fq12ElemStr*)&src->e12);
  Fq12Deserialize(&dest->e22, (Fq12ElemStr*)&src->e22);
  Fq12Deserialize(&dest->e2w, (Fq12ElemStr*)&src->e2w);
  return src + 1;
#else   // defined(UNOPTIMIZED_SERIALIZATION)
  SwapNativeAndPortableLayout(dest, sizeof(*dest), src, sizeof(*src));
  return src + 1;
#endif  // defined(UNOPTIMIZED_SERIALIZATION)
}

void const* MembershipCredentialDeserialize(NativeMembershipCredential* dest,
                                            MembershipCredential const* src) {
#if defined(UNOPTIMIZED_SERIALIZATION)
  EFqDeserialize(&dest->A, &src->A);
  FpDeserialize(&dest->x, &src->x);
  dest->gid = src->gid;
  return src + 1;
#else   // defined(UNOPTIMIZED_SERIALIZATION)
  dest->gid = src->gid;
  SwapNativeAndPortableLayout(
      (uint8_t*)dest + sizeof(dest->gid), sizeof(*dest) - sizeof(dest->gid),
      (uint8_t*)src + sizeof(src->gid), sizeof(*src) - sizeof(src->gid));
  return src + 1;
#endif  // defined(UNOPTIMIZED_SERIALIZATION)
}