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

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

?? ibeparamtype.c

?? IBE是一種非對稱密碼技術
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* 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 "ibecache.h"
#include "errorctx.h"

/* Gets the system parameters 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 VoltParameterGetBFType1IBEParams VOLT_PROTO_LIST ((
   VtParameterObject object,
   Pointer *getInfo
));

int VtParameterParamBFType1IBEParams (
   VtParameterObject object,
   Pointer info,
   unsigned int flag
   )
{
  int status;
  VoltParameterObject *obj = (VoltParameterObject *)object;
  VtBFType1IBEParamInfo *paramInfo = (VtBFType1IBEParamInfo *)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 = VoltParameterGetBFType1IBEParams (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 paramData of the object. It should be empty.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_SET;
    if (obj->paramData != (Pointer)0)
      break;

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

    /* If using this ParameterParam, the object must already have an
     * mpCtx loaded.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_PARAM_OBJ;
    if (obj->mpCtx == (VoltMpIntCtx *)0)
      break;

    /* Are the input params acceptable?
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltCheckParams (
      (VoltLibCtx *)(obj->voltObject.libraryCtx), paramInfo);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltSetIBEParams ((VtParameterObject)obj, paramInfo);

  } 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,
    "VtParameterParamBFType1IBEParams", (char *)0)

  return (status);
}

int VoltParameterGetBFType1IBEParams (
   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_TYPE_PARAMS and VOLT_PARAM_ALG_IBE_TYPE_1.
     */
    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;
    if ((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,
    "VoltParameterGetBFType1IBEParams", (char *)0)

  return (status);
}

int VoltSetIBEParams (
   VtParameterObject paramObj,
   VtBFType1IBEParamInfo *paramInfo
   )
{
  int status;
  unsigned int bufferSize, offset, baseYLen, baseXLen, pubYLen, pubXLen;
  VoltParameterObject *obj = (VoltParameterObject *)paramObj;
  VoltLibCtx *libCtx = (VoltLibCtx *)(obj->voltObject.libraryCtx);
  unsigned char *buffer = (unsigned char *)0;
  unsigned char *baseY = (unsigned char *)0;
  unsigned char *baseX = (unsigned char *)0;
  unsigned char *pubY = (unsigned char *)0;
  unsigned char *pubX = (unsigned char *)0;
  VoltBFType1IBEParams *theParams;
  VtBFType1IBEParamInfo newParamInfo;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  /* Use newParamInfo in case there are no y-coordinates.
   */
  Z2Memcpy (&newParamInfo, paramInfo, sizeof (newParamInfo));

  do
  {
    /* If the base point y-coordinate is not given, get it.
     */
    if (newParamInfo.curve.basePointG.yCoord.data == (unsigned char *)0)
    {
      VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VT_ERROR_MEMORY;
      baseYLen = newParamInfo.curve.primeP.len;
      baseY = (unsigned char *)Z2Malloc (baseYLen, 0);
      if (baseY == (unsigned char *)0)
        break;

      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltGetYCoordFromX (
        libCtx, obj->mpCtx, (bf_context_t *)0, &newParamInfo,
        newParamInfo.curve.basePointG.xCoord.data,
        newParamInfo.curve.basePointG.xCoord.len,
        baseY, baseYLen, &baseYLen);
      if (status != 0)
        break;

      newParamInfo.curve.basePointG.yCoord.data = baseY;
      newParamInfo.curve.basePointG.yCoord.len = baseYLen;
      newParamInfo.curve.basePointG.xCoord.data++;
      newParamInfo.curve.basePointG.xCoord.len--;
    }

    /* If the base point x-coordinate is not given, get it.
     */
    if (newParamInfo.curve.basePointG.xCoord.data == (unsigned char *)0)
    {
      VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VT_ERROR_MEMORY;
      baseXLen = newParamInfo.curve.primeP.len;
      baseX = (unsigned char *)Z2Malloc (baseXLen, 0);
      if (baseX == (unsigned char *)0)
        break;

      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltGetXCoordFromY (
        libCtx, obj->mpCtx, &newParamInfo,
        newParamInfo.curve.basePointG.yCoord.data,
        newParamInfo.curve.basePointG.yCoord.len,
        baseX, baseXLen, &baseXLen);
      if (status != 0)
        break;

      newParamInfo.curve.basePointG.xCoord.data = baseX;
      newParamInfo.curve.basePointG.xCoord.len = baseXLen;
    }

    /* If the pubPoint y-coordinate is not given, get it.
     */
    if (newParamInfo.pubPointP.yCoord.data == (unsigned char *)0)
    {
      VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VT_ERROR_MEMORY;
      pubYLen = newParamInfo.curve.primeP.len;
      pubY = (unsigned char *)Z2Malloc (pubYLen, 0);
      if (pubY == (unsigned char *)0)
        break;

      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltGetYCoordFromX (
        libCtx, obj->mpCtx, (bf_context_t *)0, &newParamInfo,
        newParamInfo.pubPointP.xCoord.data,
        newParamInfo.pubPointP.xCoord.len,
        pubY, pubYLen, &pubYLen);
      if (status != 0)
        break;

      newParamInfo.pubPointP.yCoord.data = pubY;
      newParamInfo.pubPointP.yCoord.len = pubYLen;
      newParamInfo.pubPointP.xCoord.data++;
      newParamInfo.pubPointP.xCoord.len--;
    }

    /* If the pubPoint x-coordinate is not given, get it.
     */
    if (newParamInfo.pubPointP.xCoord.data == (unsigned char *)0)
    {
      VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VT_ERROR_MEMORY;
      pubXLen = newParamInfo.curve.primeP.len;
      pubX = (unsigned char *)Z2Malloc (pubXLen, 0);
      if (pubX == (unsigned char *)0)
        break;

      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltGetXCoordFromY (
        libCtx, obj->mpCtx, &newParamInfo,
        newParamInfo.pubPointP.yCoord.data,
        newParamInfo.pubPointP.yCoord.len,
        pubX, pubXLen, &pubXLen);
      if (status != 0)
        break;

      newParamInfo.pubPointP.xCoord.data = pubX;
      newParamInfo.pubPointP.xCoord.len = pubXLen;
    }

    /* Allocate space to hold the param struct, the prime, subprime,
     * base point and pub 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 (VoltBFType1IBEParams) + newParamInfo.curve.primeP.len +
      newParamInfo.curve.subprimeQ.len +
      newParamInfo.curve.basePointG.xCoord.len +
      newParamInfo.curve.basePointG.yCoord.len +
      newParamInfo.pubPointP.xCoord.len + newParamInfo.pubPointP.yCoord.len;
    buffer = (unsigned char *)Z2Malloc (bufferSize, VOLT_MEMORY_SENSITIVE);
    if (buffer == (unsigned char *)0)
      break;
    Z2Memset (buffer, 0, bufferSize);

    /* Locate the structs and data.
     */
    theParams = (VoltBFType1IBEParams *)buffer;
    offset = sizeof (VoltBFType1IBEParams);
    theParams->paramInfo.curve.primeP.data = buffer + offset;
    offset += newParamInfo.curve.primeP.len;
    theParams->paramInfo.curve.subprimeQ.data = buffer + offset;
    offset += newParamInfo.curve.subprimeQ.len;
    theParams->paramInfo.curve.basePointG.xCoord.data =  buffer + offset;
    offset += newParamInfo.curve.basePointG.xCoord.len;
    theParams->paramInfo.curve.basePointG.yCoord.data =  buffer + offset;
    offset += newParamInfo.curve.basePointG.yCoord.len;
    theParams->paramInfo.pubPointP.xCoord.data = buffer + offset;
    offset += newParamInfo.pubPointP.xCoord.len;
    theParams->paramInfo.pubPointP.yCoord.data = buffer + offset;

    /* Fill in fields and copy data.
     */
    Z2Memcpy (
      theParams->paramInfo.curve.primeP.data,
      newParamInfo.curve.primeP.data, newParamInfo.curve.primeP.len);
    theParams->paramInfo.curve.primeP.len = newParamInfo.curve.primeP.len;

    Z2Memcpy (
      theParams->paramInfo.curve.subprimeQ.data,
      newParamInfo.curve.subprimeQ.data, newParamInfo.curve.subprimeQ.len);
    theParams->paramInfo.curve.subprimeQ.len = newParamInfo.curve.subprimeQ.len;

    theParams->paramInfo.curve.basePointG.isInfinity =
      newParamInfo.curve.basePointG.isInfinity;

    Z2Memcpy (
      theParams->paramInfo.curve.basePointG.xCoord.data,
      newParamInfo.curve.basePointG.xCoord.data,
      newParamInfo.curve.basePointG.xCoord.len);
    theParams->paramInfo.curve.basePointG.xCoord.len =
      newParamInfo.curve.basePointG.xCoord.len;

    Z2Memcpy (
      theParams->paramInfo.curve.basePointG.yCoord.data,
      newParamInfo.curve.basePointG.yCoord.data,
      newParamInfo.curve.basePointG.yCoord.len);
    theParams->paramInfo.curve.basePointG.yCoord.len =
      newParamInfo.curve.basePointG.yCoord.len;

    theParams->paramInfo.pubPointP.isInfinity =
      newParamInfo.pubPointP.isInfinity;
    Z2Memcpy (
      theParams->paramInfo.pubPointP.xCoord.data,
      newParamInfo.pubPointP.xCoord.data, newParamInfo.pubPointP.xCoord.len);
    theParams->paramInfo.pubPointP.xCoord.len =
      newParamInfo.pubPointP.xCoord.len;

    Z2Memcpy (
      theParams->paramInfo.pubPointP.yCoord.data,
      newParamInfo.pubPointP.yCoord.data, newParamInfo.pubPointP.yCoord.len);
    theParams->paramInfo.pubPointP.yCoord.len =
      newParamInfo.pubPointP.yCoord.len;

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

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

  } while (0);

  if (baseY != (unsigned char *)0)
    Z2Free (baseY);
  if (baseX != (unsigned char *)0)
    Z2Free (baseX);
  if (pubY != (unsigned char *)0)
    Z2Free (pubY);
  if (pubX != (unsigned char *)0)
    Z2Free (pubX);

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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩大陆一区二区| 成人午夜碰碰视频| 欧美三区在线观看| 亚洲图片一区二区| 69堂精品视频| 国产一区二区在线观看视频| 国产欧美一区二区三区在线看蜜臀| 国产河南妇女毛片精品久久久| 亚洲国产精品成人久久综合一区| 92精品国产成人观看免费| 亚洲国产综合91精品麻豆| 91精品国产入口| 成人综合婷婷国产精品久久| 中文字幕一区二区日韩精品绯色| 色婷婷av久久久久久久| 日韩高清不卡一区二区三区| 26uuu亚洲综合色| 99re亚洲国产精品| 日本aⅴ亚洲精品中文乱码| 国产亚洲成av人在线观看导航| 99久久婷婷国产精品综合| 亚洲国产成人av网| 久久久久久一二三区| 99视频有精品| 精品在线视频一区| 亚洲色图一区二区| 精品国产一区二区精华| 色综合网色综合| 九一九一国产精品| 亚洲乱码日产精品bd| 精品国产免费久久| 色综合天天性综合| 狠狠色丁香婷婷综合| 一区二区三区日韩精品视频| 精品国产一区二区三区不卡| 在线观看免费成人| 粉嫩av亚洲一区二区图片| 日韩精品国产欧美| 亚洲蜜臀av乱码久久精品| 26uuu国产在线精品一区二区| 欧美午夜不卡视频| 成人av网址在线| 久久99久久99小草精品免视看| 亚洲乱码精品一二三四区日韩在线| 亚洲精品一区二区三区四区高清 | 亚洲视频一二区| 欧美大片一区二区| 欧洲在线/亚洲| 99精品视频在线播放观看| 麻豆精品视频在线| 首页亚洲欧美制服丝腿| 亚洲天堂av一区| 日本一区二区三区dvd视频在线 | av电影在线观看完整版一区二区| 久久电影国产免费久久电影| 亚洲福利视频一区二区| 伊人色综合久久天天人手人婷| 国产日产欧美一区二区三区 | 欧美色手机在线观看| 99久久精品免费看国产| 粉嫩aⅴ一区二区三区四区| 韩国成人精品a∨在线观看| 日韩中文字幕麻豆| 亚洲高清一区二区三区| 一区二区在线免费| 亚洲你懂的在线视频| 最新国产成人在线观看| 国产精品久久久久婷婷二区次| 国产欧美一二三区| 亚洲国产高清aⅴ视频| 国产性做久久久久久| www国产成人免费观看视频 深夜成人网| 欧美精品电影在线播放| 欧美日韩高清一区二区不卡| 欧美日韩视频在线一区二区 | 美女视频黄久久| 毛片一区二区三区| 久久精品国产免费| 国产麻豆成人精品| 国产成人免费视频一区| 成人app软件下载大全免费| 春色校园综合激情亚洲| 成人精品视频.| 精品国产一区二区三区忘忧草 | 懂色一区二区三区免费观看| 懂色av中文字幕一区二区三区| 国产电影一区二区三区| 成人午夜电影网站| 99re这里只有精品视频首页| 色偷偷成人一区二区三区91 | 免费看日韩精品| 精品伊人久久久久7777人| 国产综合色视频| 成人高清视频免费观看| 91国产视频在线观看| 欧美裸体一区二区三区| 日韩精品一区二区三区在线观看 | 蓝色福利精品导航| 国产一区二区不卡在线| 成人av在线电影| 欧美日韩三级一区二区| 日韩欧美www| 中文字幕一区不卡| 亚洲高清久久久| 精品一区二区综合| 99在线精品一区二区三区| 欧美日韩视频专区在线播放| 精品伦理精品一区| 国产精品动漫网站| 爽好多水快深点欧美视频| 大胆欧美人体老妇| 7777女厕盗摄久久久| 国产日韩欧美一区二区三区综合| 亚洲丝袜精品丝袜在线| 久久精品国产秦先生| 91伊人久久大香线蕉| 欧美一区二区在线不卡| 中文字幕欧美一| 美腿丝袜在线亚洲一区| av在线不卡网| 欧美一区二区三区日韩| 亚洲色图另类专区| 久久疯狂做爰流白浆xx| 色悠悠亚洲一区二区| 精品美女被调教视频大全网站| 玉米视频成人免费看| 国产综合色精品一区二区三区| 在线观看日韩av先锋影音电影院| 久久久777精品电影网影网 | 在线免费不卡电影| 久久久精品蜜桃| 天天综合日日夜夜精品| 成人黄色av电影| 久久免费电影网| 免费人成在线不卡| 欧美少妇xxx| 亚洲乱码国产乱码精品精98午夜| 国产福利一区在线| 欧美一区二区三区播放老司机 | 午夜精品免费在线观看| 北岛玲一区二区三区四区| 日韩欧美国产综合一区| 亚洲一线二线三线久久久| 国产91在线看| 国产亚洲午夜高清国产拍精品 | 欧美久久久久免费| 亚洲蜜臀av乱码久久精品| 丁香婷婷综合五月| 久久久国产精品麻豆| 日本不卡视频一二三区| 欧美日韩一级片网站| 亚洲免费av网站| 一本大道久久a久久精品综合| 久久精品日韩一区二区三区| 久久国产生活片100| 日韩精品一区二区三区视频| 午夜视频在线观看一区二区| 91免费国产在线| 亚洲欧洲日产国码二区| 成人黄页在线观看| 国产精品亲子乱子伦xxxx裸| 国产在线视视频有精品| 国产亚洲欧美一区在线观看| 国产成人午夜片在线观看高清观看| www国产成人| 国产精品888| 国产精品福利一区二区三区| 粉嫩一区二区三区性色av| 国产精品美女久久久久久久| 97国产一区二区| 亚洲男女一区二区三区| 色菇凉天天综合网| 一区二区日韩av| 91黄色免费网站| 亚洲电影一级片| 日韩欧美国产wwwww| 久久99国产精品久久99果冻传媒 | 国产精品美女一区二区| 不卡电影一区二区三区| 中文字幕一区av| 欧美色老头old∨ideo| 亚洲成人av电影| 日韩欧美国产午夜精品| 国产精品18久久久久久久久久久久 | 国产成人在线视频播放| 欧美极品另类videosde| 99视频一区二区| 天天操天天综合网| 亚洲精品一区二区三区影院| av在线免费不卡| 亚洲不卡av一区二区三区| 精品国产91乱码一区二区三区| 国产一区二区三区免费看| ●精品国产综合乱码久久久久| 91黄视频在线观看| 久久66热re国产| 亚洲另类色综合网站| 欧美一区二区免费| 国产高清精品网站| 亚洲国产成人porn|