亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ibecurvetype.c

?? IBE是一種非對稱密碼技術
?? C
字號:
/* Copyright 2003-2006, Voltage Security, all rights reserved.
 */
#include "vibecrypto.h"
#include "environment.h"
#include "base.h"
#include "libctx.h"
#include "paramobj.h"
#include "ibe.h"
#include "mpint.h"
#include "errorctx.h"

/* Gets the curve out of a parameter object.
 *
 * @param paramObj The object from which the params are to be extracted.
 * @param getInfo The address where the function will deposit the
 * pointer to the info.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV VoltParameterGetBFType1IBECurve VOLT_PROTO_LIST ((
   VtParameterObject object,
   Pointer *getInfo
));

int VtParameterParamBFType1IBECurve (
   VtParameterObject object,
   Pointer info,
   unsigned int flag
   )
{
  int status;
  VoltParameterObject *obj = (VoltParameterObject *)object;
  VtBFType1IBECurveInfo *curveInfo = (VtBFType1IBECurveInfo *)info;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    if (flag == VOLT_PARAM_GET_TYPE_FLAG)
    {
      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltParameterGetBFType1IBECurve (object, (Pointer *)info);
      break;
    }

    /* Check the flag, it should be VOLT_PARAM_SET_TYPE_FLAG.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_TYPE;
    if (flag != VOLT_PARAM_SET_TYPE_FLAG)
      break;

    /* Check the paramType of the object. It should be 0.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_SET;
    if (obj->paramType != 0)
      break;

    /* The associated info should be a pointer to VoltageBFType1IBECurve.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if (info == (Pointer)0)
      break;

    /* Is the input curve acceptable?
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltCheckCurve (
      (VoltLibCtx *)(obj->voltObject.libraryCtx), curveInfo);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltSetIBECurve (obj, curveInfo);

  } while (0);

  /* If everything worked, return 0.
   */
  if (status == 0)
    return (0);

  /* If something went wrong, indicate that this object is not usable.
   */
  obj->paramType = 0;

  VOLT_LOG_ERROR (
    obj->voltObject.libraryCtx, status, errorType, fnctLine,
    "VtParameterParamBFType1IBECurve", (char *)0)

  return (status);
}

int VoltParameterGetBFType1IBECurve (
   VtParameterObject object,
   Pointer *getInfo
   )
{
  int status;
  VoltParameterObject *obj = (VoltParameterObject *)object;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* Check the paramType in the object, it should contain
     * VOLT_PARAM_ALG_IBE_TYPE_1 and the either VOLT_PARAM_TYPE_CURVE
     * or VOLT_PARAM_TYPE_PARAMS.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_GET_INFO_UNAVAILABLE;
    if (obj->paramType == 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    if ((obj->paramType & VOLT_PARAM_TYPE_MASK_ALG) !=
        VOLT_PARAM_ALG_IBE_TYPE_1)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    if ( ((obj->paramType & VOLT_PARAM_TYPE_CURVE) == 0) &&
         ((obj->paramType & VOLT_PARAM_TYPE_PARAMS) == 0) )
      break;

    /* Are the parameters in data format? If so, we're done. (Set the
     * return values.)
     */
    *getInfo = obj->paramData;
    status = 0;
    if ((obj->paramType & VOLT_PARAM_TYPE_MASK_DATA) == VOLT_PARAM_TYPE_DATA)
      break;

    /* The data is not available, does the object have a GetData
     * function?
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    *getInfo = (Pointer)0;
    status = VT_ERROR_INVALID_GET;
    if (obj->GetParamData == (VGetParamData)0)
      break;

    /* Call the Get function.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = obj->GetParamData ((VtParameterObject)obj, getInfo);

  } while (0);

  VOLT_LOG_ERROR_COMPARE (
    status, obj->voltObject.libraryCtx, status, errorType, fnctLine,
    "VoltParameterGetBFType1IBECurve", (char *)0)

  return (status);
}

int VoltSetIBECurve (
   VoltParameterObject *obj,
   VtBFType1IBECurveInfo *curveInfo
   )
{
  int status;
  unsigned int bufferSize, offset;
  VoltLibCtx *libCtx = (VoltLibCtx *)(obj->voltObject.libraryCtx);
  unsigned char *buffer = (unsigned char *)0;
  VoltBFType1IBECurve *theCurve;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* Allocate space to hold the curve struct, the prime, subprime and
     * base point. After the struct, all the data is byte arrays, so
     * there's no need to worry about alignment.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_MEMORY;
    bufferSize =
      sizeof (VoltBFType1IBECurve) + curveInfo->primeP.len +
      curveInfo->subprimeQ.len + curveInfo->basePointG.xCoord.len +
      curveInfo->basePointG.yCoord.len;
    buffer = (unsigned char *)Z2Malloc (bufferSize, 0);
    if (buffer == (unsigned char *)0)
      break;
    Z2Memset (buffer, 0, bufferSize);

    /* Locate the structs and data.
     */
    theCurve = (VoltBFType1IBECurve *)buffer;
    offset = sizeof (VoltBFType1IBECurve);
    theCurve->curveData.primeP.data = buffer + offset;
    offset += curveInfo->primeP.len;
    theCurve->curveData.subprimeQ.data = buffer + offset;
    offset += curveInfo->subprimeQ.len;
    theCurve->curveData.basePointG.xCoord.data = buffer + offset;
    offset += curveInfo->basePointG.xCoord.len;
    theCurve->curveData.basePointG.yCoord.data = buffer + offset;

    /* Set these values "early" so we have the destructor in place if
     * something goes wrong.
     */
    obj->paramData = (Pointer)theCurve;
    obj->CopyParams = BFType1IBECopyCurve;
    obj->ParamDataDestroy = BFType1IBECurveDataDestroy;
    obj->paramType =
      VOLT_PARAM_ALG_IBE_TYPE_1 | VOLT_PARAM_TYPE_CURVE |
      VOLT_PARAM_TYPE_CONTENTS | VOLT_PARAM_TYPE_DATA;

    /* Fill in fields and copy data.
     */
    theCurve->curveData.basePointG.isInfinity = 0;

    Z2Memcpy (
      theCurve->curveData.primeP.data, curveInfo->primeP.data,
      curveInfo->primeP.len);
    theCurve->curveData.primeP.len = curveInfo->primeP.len;

    Z2Memcpy (
      theCurve->curveData.subprimeQ.data, curveInfo->subprimeQ.data,
      curveInfo->subprimeQ.len);
    theCurve->curveData.subprimeQ.len = curveInfo->subprimeQ.len;

    Z2Memcpy (
      theCurve->curveData.basePointG.xCoord.data,
      curveInfo->basePointG.xCoord.data, curveInfo->basePointG.xCoord.len);
    theCurve->curveData.basePointG.xCoord.len =
      curveInfo->basePointG.xCoord.len;

    Z2Memcpy (
      theCurve->curveData.basePointG.yCoord.data,
      curveInfo->basePointG.yCoord.data, curveInfo->basePointG.yCoord.len);
    theCurve->curveData.basePointG.yCoord.len =
      curveInfo->basePointG.yCoord.len;

    /* Now get the bfCtx.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltGetBfCtxFromIBEParams (
      libCtx, (VtMpIntCtx)(obj->mpCtx), &(theCurve->curveData),
      (VtBFType1IBEPoint *)0, 0, (unsigned char *)0, &(theCurve->bfCtx));

  } while (0);

  /* If everything worked, return 0.
   */
  if (status == 0)
    return (0);

  /* If something went wrong, indicate that this object is not usable.
   */
  obj->paramType = 0;

  VOLT_LOG_ERROR (
    (VtLibCtx)libCtx, status, errorType, fnctLine,
    "VoltSetIBECurve", (char *)0)

  return (status);
}

void BFType1IBECurveDataDestroy (
   Pointer paramObj,
   Pointer ctx
   )
{
  VoltParameterObject *obj = (VoltParameterObject *)paramObj;
  VoltLibCtx *libCtx = (VoltLibCtx *)(obj->voltObject.libraryCtx);
  VoltBFType1IBECurve *theCurve = (VoltBFType1IBECurve *)(obj->paramData);

  /* Is there anything to destroy?
   */
  if (obj->paramData == (Pointer)0)
    return;

  VoltReleaseBfCtx (libCtx, &(theCurve->bfCtx));

  Z2Free (obj->paramData);
}

int BFType1IBECopyCurve (
   Pointer sourceParamObj,
   Pointer destParamObj
   )
{
  int status;
  VoltParameterObject *src = (VoltParameterObject *)sourceParamObj;
  VoltParameterObject *dest = (VoltParameterObject *)destParamObj;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    dest->paramType = src->paramType;
    dest->CopyParams = src->CopyParams;
    dest->GetParamData = src->GetParamData;
    dest->ParamDataDestroy = src->ParamDataDestroy;

    /* If there's no paramData, we're done.
     */
    if (src->paramData == (Pointer)0)
      break;

    /* Is the paramData data or a handle?
     * If a handle, we should not be in this code.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_GET;
    if ((src->paramType & VOLT_PARAM_TYPE_MASK_DATA) != VOLT_PARAM_TYPE_DATA)
      break;

    /* Just call the Set function to copy the data.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltSetIBECurve (
      dest, (VtBFType1IBECurveInfo *)(src->paramData));

  } while (0);

  VOLT_LOG_ERROR_COMPARE (
    status, src->voltObject.libraryCtx, status, errorType, fnctLine,
    "BFType1IBECopyCurve", (char *)0)

  return (status);
}

int VoltCheckCurve (
   VoltLibCtx *libCtx,
   VtBFType1IBECurveInfo *curveInfo
   )
{
  int status;
  unsigned int primeLen;
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if ( (curveInfo->primeP.data == (unsigned char *)0) ||
         (curveInfo->subprimeQ.data == (unsigned char *)0) )
      break;

    primeLen = curveInfo->primeP.len;

    /* The base point cannot be infinity.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    if (curveInfo->basePointG.isInfinity != 0)
      break;

    /* The length of the point's coordinates should be the same size as
     * the primeP. Unless there is no y-coordinate, in which case the
     * x-coordinate must have an extra byte.
     */
    if (curveInfo->basePointG.yCoord.data == (unsigned char *)0)
    {
      VOLT_SET_FNCT_LINE (fnctLine)
      if (curveInfo->basePointG.xCoord.data == (unsigned char *)0)
        break;
      VOLT_SET_FNCT_LINE (fnctLine)
      if (curveInfo->basePointG.xCoord.len > (primeLen + 1))
        break;
      VOLT_SET_FNCT_LINE (fnctLine)
      if (curveInfo->basePointG.yCoord.len != 0)
        break;
    }
    else
    {
      VOLT_SET_FNCT_LINE (fnctLine)
      if (curveInfo->basePointG.yCoord.len > primeLen)
        break;
      if (curveInfo->basePointG.xCoord.data != (unsigned char *)0)
      {
        VOLT_SET_FNCT_LINE (fnctLine)
        if (curveInfo->basePointG.xCoord.len > primeLen)
          break;
      }
      else
      {
        VOLT_SET_FNCT_LINE (fnctLine)
        if (curveInfo->basePointG.xCoord.len != 0)
          break;
      }
    }

    status = 0;

  } while (0);

  VOLT_LOG_ERROR_COMPARE (
    status, (VtLibCtx)libCtx, status, VT_ERROR_TYPE_PRIMARY, fnctLine,
    "VoltCheckCurve", (char *)0)

  return (status);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费在线视频一区 二区| 亚洲视频一二三区| 99国产欧美另类久久久精品| 日本午夜一区二区| 亚洲欧美日韩国产综合| 日韩一区二区免费在线电影| 91视频精品在这里| 国产麻豆成人传媒免费观看| 亚洲成人午夜电影| 日韩伦理电影网| 久久只精品国产| 91精品国产综合久久久久| 99re视频这里只有精品| 国产高清在线精品| 免费成人小视频| 午夜精品久久久久久久蜜桃app| 国产精品久久一级| 久久久久久毛片| 欧美一区二区福利视频| 欧美色图激情小说| 91天堂素人约啪| 成人免费看黄yyy456| 极品少妇xxxx精品少妇偷拍| 青青草原综合久久大伊人精品| 亚洲精品国产视频| 亚洲欧美一区二区视频| 久久精品一区八戒影视| 26uuu国产日韩综合| 在线播放中文字幕一区| 欧美日韩中文一区| 欧美色综合网站| 欧美自拍丝袜亚洲| 色综合网站在线| 91在线你懂得| 91亚洲男人天堂| 91精品福利视频| 在线精品视频一区二区| 色综合激情五月| 日本精品一级二级| 色94色欧美sute亚洲13| 欧洲精品在线观看| 欧美性色aⅴ视频一区日韩精品| 91成人网在线| 欧美影视一区二区三区| 欧美精品 国产精品| 欧美精选在线播放| 欧美一区二区精品| 精品成人私密视频| 国产亲近乱来精品视频| 国产精品美女一区二区三区 | 91成人看片片| 91福利国产成人精品照片| 日本精品免费观看高清观看| 欧美性一区二区| 在线播放欧美女士性生活| 日韩亚洲欧美一区| 久久蜜臀中文字幕| 国产精品国产三级国产有无不卡| ...中文天堂在线一区| 亚洲精品综合在线| 偷拍一区二区三区四区| 免费在线看一区| 国产伦理精品不卡| 色综合色狠狠综合色| 欧美四级电影在线观看| 日韩区在线观看| 久久久亚洲国产美女国产盗摄 | 日韩中文字幕91| 久久99九九99精品| 91社区在线播放| 欧美精品 国产精品| 久久麻豆一区二区| 亚洲综合激情网| 精品在线播放免费| aaa亚洲精品一二三区| 欧美日韩亚州综合| 欧美精品一区二区三区四区| 国产精品久久久久久久久快鸭| 一卡二卡三卡日韩欧美| 美女www一区二区| www.亚洲色图.com| 4438x成人网最大色成网站| 久久精品一区四区| 亚洲国产一区在线观看| 国产激情一区二区三区桃花岛亚洲| 色婷婷亚洲精品| 精品欧美一区二区三区精品久久 | 九九精品一区二区| 91免费视频网址| 欧美大片日本大片免费观看| 国产精品国产a级| 日本人妖一区二区| 91啪亚洲精品| 精品国产91洋老外米糕| 一区av在线播放| 国产91精品露脸国语对白| 欧美理论片在线| 中文字幕一区二区三区视频| 老鸭窝一区二区久久精品| 在线免费不卡视频| 国产精品福利电影一区二区三区四区| 日韩在线卡一卡二| 在线看日本不卡| 亚洲国产电影在线观看| 老汉av免费一区二区三区| 欧美日韩午夜在线| 国产精品三级视频| 国产主播一区二区三区| 3atv一区二区三区| 亚洲一区自拍偷拍| 一本久久精品一区二区| 国产欧美日产一区| 国产一区三区三区| 日韩三级免费观看| 日韩精品91亚洲二区在线观看 | 高清不卡在线观看av| 在线视频综合导航| 国产视频一区二区在线| 爽好多水快深点欧美视频| 国产高清无密码一区二区三区| 欧美一级二级三级蜜桃| 亚洲综合一区二区精品导航| 国产毛片精品国产一区二区三区| 欧美精品 日韩| 中文字幕一区日韩精品欧美| 成人黄色大片在线观看| 日韩欧美黄色影院| 亚洲一区二区免费视频| www.成人在线| 久久精品综合网| 国产91丝袜在线播放0| 日韩区在线观看| 日韩精品电影一区亚洲| 欧美综合色免费| 亚洲少妇30p| 欧洲亚洲国产日韩| 亚洲精品免费在线播放| 成人午夜视频免费看| 久久综合久久综合九色| 午夜激情综合网| 欧美一区二区在线播放| 亚洲高清免费观看| 欧美唯美清纯偷拍| 一区二区在线免费| 91免费国产视频网站| 亚洲免费av网站| 91在线观看美女| 自拍偷拍国产精品| aaa国产一区| 亚洲福利视频导航| 欧美日韩国产一二三| 亚洲第一激情av| 欧美无砖砖区免费| 国产精品乱码一区二三区小蝌蚪| 99国产精品久| 一区二区在线观看视频在线观看| 色婷婷久久久亚洲一区二区三区 | 国产精选一区二区三区| 久久综合丝袜日本网| 国产资源在线一区| 精品国产乱码久久久久久闺蜜| 成人爽a毛片一区二区免费| 日本一区二区三区在线不卡| 风间由美一区二区三区在线观看 | 日韩欧美久久久| 日韩av网站免费在线| 日韩欧美一级片| 国产乱码精品一品二品| 国产精品传媒视频| 欧美制服丝袜第一页| 麻豆精品一区二区三区| 国产亚洲欧美一区在线观看| 99热在这里有精品免费| 亚洲最大的成人av| 欧美在线影院一区二区| 精品亚洲porn| 国产精品福利一区| 欧美日韩综合在线| 久久精品国产一区二区三 | av亚洲产国偷v产偷v自拍| 久久久久青草大香线综合精品| 国产精一品亚洲二区在线视频| 国产精品麻豆99久久久久久| 色丁香久综合在线久综合在线观看| 老司机午夜精品| 国产精品国产三级国产| 欧美日韩一区二区三区四区 | 中文字幕一区二区三区乱码在线| 92精品国产成人观看免费| 五月天久久比比资源色| 久久久精品tv| 欧美三级视频在线观看| 日日夜夜免费精品| 综合网在线视频| 日韩一区二区视频| 成人免费视频网站在线观看| 午夜不卡av在线| 亚洲精品久久7777| 欧美刺激脚交jootjob| 91丨九色丨黑人外教|